Frank Chang
		
	
	
		ae000c5f65
		
	
	
	
	hw/dma: sifive_pdma: don't set Control.error if 0 bytes to transfer
		
			
			Real PDMA doesn't set Control.error if there are 0 bytes to be
transferred. The DMA transfer is still success.
The following result is PDMA tested in U-Boot on Unmatched board:
=> mw.l 0x3000000 0x0                      <= Disclaim channel 0
=> mw.l 0x3000000 0x1                      <= Claim channel 0
=> mw.l 0x3000004 0x55000000               <= wsize = rsize = 5 (2^5 = 32 bytes)
=> mw.q 0x3000008 0x0                      <= NextBytes = 0
=> mw.q 0x3000010 0x84000000               <= NextDestination = 0x84000000
=> mw.q 0x3000018 0x84001000               <= NextSource = 0x84001000
=> mw.l 0x84000000 0x87654321              <= Fill test data to dst
=> mw.l 0x84001000 0x12345678              <= Fill test data to src
=> md.l 0x84000000 1; md.l 0x84001000 1    <= Dump src/dst memory contents
84000000: 87654321                               !Ce.
84001000: 12345678                               xV4.
=> md.l 0x3000000 8                        <= Dump PDMA status
03000000: 00000001 55000000 00000000 00000000    .......U........
03000010: 84000000 00000000 84001000 00000000    ................
=> mw.l 0x3000000 0x3                      <= Set channel 0 run and claim bits
=> md.l 0x3000000 8                        <= Dump PDMA status
03000000: 40000001 55000000 00000000 00000000    ...@...U........
03000010: 84000000 00000000 84001000 00000000    ................
=> md.l 0x84000000 1; md.l 0x84001000 1    <= Dump src/dst memory contents
84000000: 87654321                               !Ce.
84001000: 12345678                               xV4.
Signed-off-by: Frank Chang <frank.chang@sifive.com>
Tested-by: Max Hsu <max.hsu@sifive.com>
Reviewed-by: Bin Meng <bmeng.cn@gmail.com>
Tested-by: Bin Meng <bmeng.cn@gmail.com>
Message-id: 20210912130553.179501-5-frank.chang@sifive.com
Signed-off-by: Alistair Francis <alistair.francis@wdc.com>
		
	
 
		2021-09-21 07:56:49 +10:00
	 
	
	
		 ..
	
	
	
		
			
			
			
			
			
			2020-07-10 15:18:08 +02:00
		 
	
		
			
			
			
			
			
			2020-02-20 14:47:08 +01:00
		 
	
		
			
			
			
			
			
			2020-08-27 14:04:54 -04:00
		 
	
		
			
			
			
			
			
			2020-09-18 14:12:32 -04:00
		 
	
		
			
			
			
			
			
			2021-03-08 17:20:04 +00:00
		 
	
		
			
			
			
			
			
			2021-05-12 18:20:52 +02:00
		 
	
		
			
			
			
			
			
			2019-08-21 10:55:23 +02:00
		 
	
		
			
			
			
			
			
			2021-05-02 17:24:51 +02:00
		 
	
		
			
			
			
			
			
			2021-08-25 10:48:50 +01:00
		 
	
		
			
			
			
			
			
			2021-05-02 17:24:50 +02:00
		 
	
		
			
			
			
			
			
			2020-09-18 14:12:32 -04:00
		 
	
		
			
			
			
			
			
			2021-09-21 07:56:49 +10:00
		 
	
		
			
			
			
			
			
			2020-03-16 22:07:42 +01:00
		 
	
		
			
			
			
			
			
			2021-03-07 10:39:05 +00:00
		 
	
		
			
			
			
			
			
			2021-06-02 06:51:09 +02:00
		 
	
		
			
			
			
			
			
			2020-08-21 06:18:24 -04:00
		 
	
		
			
			
			
			
			
			2020-12-10 12:15:04 -05:00
		 
	
		
			
			
			
			
			
			2021-08-26 17:01:59 +01:00
		 
	
		
			
			
			
			
			
			2020-09-11 21:25:59 +02:00
		 
	
		
			
			
			
			
			
			2021-08-26 17:01:59 +01:00
		 
	
		
			
			
			
			
			
			2019-08-16 13:31:53 +02:00