[PATCH umr] Continue reading PDB if V=0 if in vm-decode mode

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



This will skip to the next page boundary (assumes page=4K right now) if
in --vm-decode mode.

Signed-off-by: Tom St Denis <tom.stdenis at amd.com>
Reported-by: Christian König <christian.koenig at amd.com>
---
 src/lib/read_vram.c | 25 +++++++++++++++++++++----
 1 file changed, 21 insertions(+), 4 deletions(-)

diff --git a/src/lib/read_vram.c b/src/lib/read_vram.c
index 491a55f69d49..3331b3e66d24 100644
--- a/src/lib/read_vram.c
+++ b/src/lib/read_vram.c
@@ -221,8 +221,15 @@ static int umr_access_vram_vi(struct umr_asic *asic, uint32_t vmid,
 						(int)pde_fields.valid);
 			memcpy(&pde_copy, &pde_fields, sizeof pde_fields);
 
-			if (!pde_fields.valid)
-				return -1;
+			if (!pde_fields.valid) {
+				if (pdst)
+					return -1;
+
+				// if we are vm-decode'ing just jump
+				// to the next page
+				start_addr = address & 0xFFF; // grab page offset so we can advance to next page
+				goto next_page;
+			}
 
 			// now read PTE entry for this page
 			if (umr_read_vram(asic, UMR_LINEAR_HUB, pde_fields.pte_base_addr + pte_idx*8 - vm_fb_base, 8, &pte_entry) < 0)
@@ -273,6 +280,7 @@ static int umr_access_vram_vi(struct umr_asic *asic, uint32_t vmid,
 			start_addr = dma_to_phys(asic, pte_fields.page_base_addr) + (address & 0xFFF);
 		}
 
+next_page:
 		// read upto 4K from it
 		if (((start_addr & 0xFFF) + size) & ~0xFFF) {
 			chunk_size = 0x1000 - (start_addr & 0xFFF);
@@ -528,8 +536,16 @@ static int umr_access_vram_ai(struct umr_asic *asic, uint32_t vmid,
 				if (!pde_fields.system)
 					pde_fields.pte_base_addr -= vm_fb_offset;
 
-				if (!pde_fields.valid)
-					return -1;
+				if (!pde_fields.valid) {
+					if (pdst)
+						return -1;
+					// jump to next page if in
+					// vm-decode mode
+					pte_fields.prt = 0;
+					pte_fields.valid = 0;
+					start_addr = address & 0xFFF; // grab page offset so we can advance to next page
+					goto next_page;
+				}
 
 				// for the next round the address we're decoding is the phys address in the currently decoded PDE
 				--current_depth;
@@ -632,6 +648,7 @@ pde_is_pte:
 			start_addr = dma_to_phys(asic, pte_fields.page_base_addr) + (address & 0xFFF);
 		}
 
+next_page:
 		// read upto 4K from it
 		// TODO: Support page sizes >4KB
 		if (((start_addr & 0xFFF) + size) & ~0xFFF) {
-- 
2.14.3



[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux