diff options
author | Chunming Zhou <david1.zhou@amd.com> | 2018-02-08 21:44:09 -0500 |
---|---|---|
committer | Alex Deucher <alexander.deucher@amd.com> | 2018-02-13 13:33:32 -0500 |
commit | fd5fd480dd8fe4910546e7b080b3ae345e57fe9f (patch) | |
tree | 3eff145418a91d1fd03a226763c122dee882bb15 | |
parent | 82626363a217d79128c447ab296777b461e9f050 (diff) |
drm/amdgpu: only enable swiotlb alloc when need v2
get the max io mapping address of system memory to see if it is over
our card accessing range.
v2: move checking later
Signed-off-by: Chunming Zhou <david1.zhou@amd.com>
Reviewed-by: Monk Liu <monk.liu@amd.com>
Reviewed-by: Christian König <christian.koenig@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20180209024410.1469-2-david1.zhou@amd.com
-rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu.h | 1 | ||||
-rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c | 6 | ||||
-rw-r--r-- | drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c | 2 | ||||
-rw-r--r-- | drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c | 2 | ||||
-rw-r--r-- | drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c | 3 | ||||
-rw-r--r-- | drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c | 2 |
6 files changed, 13 insertions, 3 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu.h b/drivers/gpu/drm/amd/amdgpu/amdgpu.h index d5a2eefd6c3e..31126df06c8c 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu.h +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu.h | |||
@@ -1504,6 +1504,7 @@ struct amdgpu_device { | |||
1504 | const struct amdgpu_asic_funcs *asic_funcs; | 1504 | const struct amdgpu_asic_funcs *asic_funcs; |
1505 | bool shutdown; | 1505 | bool shutdown; |
1506 | bool need_dma32; | 1506 | bool need_dma32; |
1507 | bool need_swiotlb; | ||
1507 | bool accel_working; | 1508 | bool accel_working; |
1508 | struct work_struct reset_work; | 1509 | struct work_struct reset_work; |
1509 | struct notifier_block acpi_nb; | 1510 | struct notifier_block acpi_nb; |
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c index e4bb435e614b..d897c4c61a01 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c | |||
@@ -1018,7 +1018,7 @@ static int amdgpu_ttm_tt_populate(struct ttm_tt *ttm, | |||
1018 | } | 1018 | } |
1019 | 1019 | ||
1020 | #ifdef CONFIG_SWIOTLB | 1020 | #ifdef CONFIG_SWIOTLB |
1021 | if (swiotlb_nr_tbl()) { | 1021 | if (adev->need_swiotlb && swiotlb_nr_tbl()) { |
1022 | return ttm_dma_populate(>t->ttm, adev->dev, ctx); | 1022 | return ttm_dma_populate(>t->ttm, adev->dev, ctx); |
1023 | } | 1023 | } |
1024 | #endif | 1024 | #endif |
@@ -1045,7 +1045,7 @@ static void amdgpu_ttm_tt_unpopulate(struct ttm_tt *ttm) | |||
1045 | adev = amdgpu_ttm_adev(ttm->bdev); | 1045 | adev = amdgpu_ttm_adev(ttm->bdev); |
1046 | 1046 | ||
1047 | #ifdef CONFIG_SWIOTLB | 1047 | #ifdef CONFIG_SWIOTLB |
1048 | if (swiotlb_nr_tbl()) { | 1048 | if (adev->need_swiotlb && swiotlb_nr_tbl()) { |
1049 | ttm_dma_unpopulate(>t->ttm, adev->dev); | 1049 | ttm_dma_unpopulate(>t->ttm, adev->dev); |
1050 | return; | 1050 | return; |
1051 | } | 1051 | } |
@@ -2010,7 +2010,7 @@ static int amdgpu_ttm_debugfs_init(struct amdgpu_device *adev) | |||
2010 | count = ARRAY_SIZE(amdgpu_ttm_debugfs_list); | 2010 | count = ARRAY_SIZE(amdgpu_ttm_debugfs_list); |
2011 | 2011 | ||
2012 | #ifdef CONFIG_SWIOTLB | 2012 | #ifdef CONFIG_SWIOTLB |
2013 | if (!swiotlb_nr_tbl()) | 2013 | if (!(adev->need_swiotlb && swiotlb_nr_tbl())) |
2014 | --count; | 2014 | --count; |
2015 | #endif | 2015 | #endif |
2016 | 2016 | ||
diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c b/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c index 8e28270d1ea9..5f5eb15ccf4a 100644 --- a/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c +++ b/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c | |||
@@ -22,6 +22,7 @@ | |||
22 | */ | 22 | */ |
23 | #include <linux/firmware.h> | 23 | #include <linux/firmware.h> |
24 | #include <drm/drmP.h> | 24 | #include <drm/drmP.h> |
25 | #include <drm/drm_cache.h> | ||
25 | #include "amdgpu.h" | 26 | #include "amdgpu.h" |
26 | #include "gmc_v6_0.h" | 27 | #include "gmc_v6_0.h" |
27 | #include "amdgpu_ucode.h" | 28 | #include "amdgpu_ucode.h" |
@@ -851,6 +852,7 @@ static int gmc_v6_0_sw_init(void *handle) | |||
851 | pci_set_consistent_dma_mask(adev->pdev, DMA_BIT_MASK(32)); | 852 | pci_set_consistent_dma_mask(adev->pdev, DMA_BIT_MASK(32)); |
852 | dev_warn(adev->dev, "amdgpu: No coherent DMA available.\n"); | 853 | dev_warn(adev->dev, "amdgpu: No coherent DMA available.\n"); |
853 | } | 854 | } |
855 | adev->need_swiotlb = drm_get_max_iomem() > ((u64)1 << dma_bits); | ||
854 | 856 | ||
855 | r = gmc_v6_0_init_microcode(adev); | 857 | r = gmc_v6_0_init_microcode(adev); |
856 | if (r) { | 858 | if (r) { |
diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c b/drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c index 86e9d682c59e..12e49bd8fd2d 100644 --- a/drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c +++ b/drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c | |||
@@ -22,6 +22,7 @@ | |||
22 | */ | 22 | */ |
23 | #include <linux/firmware.h> | 23 | #include <linux/firmware.h> |
24 | #include <drm/drmP.h> | 24 | #include <drm/drmP.h> |
25 | #include <drm/drm_cache.h> | ||
25 | #include "amdgpu.h" | 26 | #include "amdgpu.h" |
26 | #include "cikd.h" | 27 | #include "cikd.h" |
27 | #include "cik.h" | 28 | #include "cik.h" |
@@ -999,6 +1000,7 @@ static int gmc_v7_0_sw_init(void *handle) | |||
999 | pci_set_consistent_dma_mask(adev->pdev, DMA_BIT_MASK(32)); | 1000 | pci_set_consistent_dma_mask(adev->pdev, DMA_BIT_MASK(32)); |
1000 | pr_warn("amdgpu: No coherent DMA available\n"); | 1001 | pr_warn("amdgpu: No coherent DMA available\n"); |
1001 | } | 1002 | } |
1003 | adev->need_swiotlb = drm_get_max_iomem() > ((u64)1 << dma_bits); | ||
1002 | 1004 | ||
1003 | r = gmc_v7_0_init_microcode(adev); | 1005 | r = gmc_v7_0_init_microcode(adev); |
1004 | if (r) { | 1006 | if (r) { |
diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c b/drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c index 9a813d834f1a..9a170e37fbe7 100644 --- a/drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c +++ b/drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c | |||
@@ -22,6 +22,7 @@ | |||
22 | */ | 22 | */ |
23 | #include <linux/firmware.h> | 23 | #include <linux/firmware.h> |
24 | #include <drm/drmP.h> | 24 | #include <drm/drmP.h> |
25 | #include <drm/drm_cache.h> | ||
25 | #include "amdgpu.h" | 26 | #include "amdgpu.h" |
26 | #include "gmc_v8_0.h" | 27 | #include "gmc_v8_0.h" |
27 | #include "amdgpu_ucode.h" | 28 | #include "amdgpu_ucode.h" |
@@ -1085,6 +1086,7 @@ static int gmc_v8_0_sw_init(void *handle) | |||
1085 | */ | 1086 | */ |
1086 | adev->need_dma32 = false; | 1087 | adev->need_dma32 = false; |
1087 | dma_bits = adev->need_dma32 ? 32 : 40; | 1088 | dma_bits = adev->need_dma32 ? 32 : 40; |
1089 | adev->need_swiotlb = drm_get_max_iomem() > ((u64)1 << dma_bits); | ||
1088 | r = pci_set_dma_mask(adev->pdev, DMA_BIT_MASK(dma_bits)); | 1090 | r = pci_set_dma_mask(adev->pdev, DMA_BIT_MASK(dma_bits)); |
1089 | if (r) { | 1091 | if (r) { |
1090 | adev->need_dma32 = true; | 1092 | adev->need_dma32 = true; |
@@ -1096,6 +1098,7 @@ static int gmc_v8_0_sw_init(void *handle) | |||
1096 | pci_set_consistent_dma_mask(adev->pdev, DMA_BIT_MASK(32)); | 1098 | pci_set_consistent_dma_mask(adev->pdev, DMA_BIT_MASK(32)); |
1097 | pr_warn("amdgpu: No coherent DMA available\n"); | 1099 | pr_warn("amdgpu: No coherent DMA available\n"); |
1098 | } | 1100 | } |
1101 | adev->need_swiotlb = drm_get_max_iomem() > ((u64)1 << dma_bits); | ||
1099 | 1102 | ||
1100 | r = gmc_v8_0_init_microcode(adev); | 1103 | r = gmc_v8_0_init_microcode(adev); |
1101 | if (r) { | 1104 | if (r) { |
diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c index eb8b1bb66389..71d3aedefd69 100644 --- a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c +++ b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c | |||
@@ -21,6 +21,7 @@ | |||
21 | * | 21 | * |
22 | */ | 22 | */ |
23 | #include <linux/firmware.h> | 23 | #include <linux/firmware.h> |
24 | #include <drm/drm_cache.h> | ||
24 | #include "amdgpu.h" | 25 | #include "amdgpu.h" |
25 | #include "gmc_v9_0.h" | 26 | #include "gmc_v9_0.h" |
26 | #include "amdgpu_atomfirmware.h" | 27 | #include "amdgpu_atomfirmware.h" |
@@ -850,6 +851,7 @@ static int gmc_v9_0_sw_init(void *handle) | |||
850 | pci_set_consistent_dma_mask(adev->pdev, DMA_BIT_MASK(32)); | 851 | pci_set_consistent_dma_mask(adev->pdev, DMA_BIT_MASK(32)); |
851 | printk(KERN_WARNING "amdgpu: No coherent DMA available.\n"); | 852 | printk(KERN_WARNING "amdgpu: No coherent DMA available.\n"); |
852 | } | 853 | } |
854 | adev->need_swiotlb = drm_get_max_iomem() > ((u64)1 << dma_bits); | ||
853 | 855 | ||
854 | r = gmc_v9_0_mc_init(adev); | 856 | r = gmc_v9_0_mc_init(adev); |
855 | if (r) | 857 | if (r) |