Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						31798907b7 
					 
					
						
						
							
							hw/sd/sdcard: Add sd_cmd_SEND_IF_COND handler (CMD8)  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-50-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						9193deb406 
					 
					
						
						
							
							hw/sd/sdcard: Add sd_cmd_DE/SELECT_CARD handler (CMD7)  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-49-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						4064824fb7 
					 
					
						
						
							
							hw/sd/sdcard: Add sd_cmd_SWITCH_FUNCTION handler (CMD6)  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org >
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-48-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						f274e6f590 
					 
					
						
						
							
							hw/sd/sdcard: Register Security Extension optional handlers  
						
						... 
						
						
						
						See "Advanced Security SD Extension Specification" v2.00.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-47-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						9b2e17756f 
					 
					
						
						
							
							hw/sd/sdcard: Register SDIO optional handlers  
						
						... 
						
						
						
						See "SD Input/Output Card Specification" v1.00.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-46-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						a3e8ca8381 
					 
					
						
						
							
							hw/sd/sdcard: Register optional handlers from spec v6.00  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-45-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						720c0f3e6c 
					 
					
						
						
							
							hw/sd/sdcard: Register generic optional handlers (CMD11 and CMD20)  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-44-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						617c5a7345 
					 
					
						
						
							
							hw/sd/sdcard: Remove SEND_DSR dead case (CMD4)  
						
						... 
						
						
						
						The CSD::CSR_IMP bit defines whether the Driver Stage
Register (DSR) is implemented or not. We do not set
this bit in CSD:
    static void sd_set_csd(SDState *sd, uint64_t size)
    {
        ...
        if (size <= SDSC_MAX_CAPACITY) { /* Standard Capacity SD */
            ...
            sd->csd[6] = 0xe0 |     /* Partial block for read allowed */
                ((csize >> 10) & 0x03);
            ...
        } else {                    /* SDHC */
            ...
            sd->csd[6] = 0x00;
            ...
        }
        ...
    }
The sd_normal_command() switch case for the SEND_DSR
command do nothing and fallback to "illegal command".
Since the command is mandatory (although the register
isn't...) call the sd_cmd_unimplemented() handler.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-43-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						de32f0aa9a 
					 
					
						
						
							
							hw/sd/sdcard: Store command class in SDProto  
						
						... 
						
						
						
						Store the command class altogether with the other command
fields (handler, name and type).
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-42-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						1ab08790bb 
					 
					
						
						
							
							hw/sd/sdcard: Store command type in SDProto  
						
						... 
						
						
						
						Store the command type altogether with the command handler and name.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-41-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						572cdb1d90 
					 
					
						
						
							
							hw/sd/sdcard: Store command name in SDProto  
						
						... 
						
						
						
						We already have a const array where command handlers
are listed. Store the command name there too.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-40-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						4518a49a01 
					 
					
						
						
							
							hw/sd/sdcard: Prepare SDProto to contain more fields  
						
						... 
						
						
						
						Convert array of command handlers to array of structures.
The structure contains the command handler. No logical
change intended.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-39-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						fb72e681c9 
					 
					
						
						
							
							hw/sd/sdcard: Pass SDState as argument to sd_[a]cmd_name()  
						
						... 
						
						
						
						In order to access SDState::SDProto from sd_[a]cmd_name(),
pass SDState as argument.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-38-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						d4613f9f40 
					 
					
						
						
							
							hw/sd/sdcard: Move sd_[a]cmd_name() methods to sd.c  
						
						... 
						
						
						
						Merge sdmmc-internal.c into sd.c by moving
sd_cmd_name() and sd_acmd_name() and updating
meson.build.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-37-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						77a2f97d1d 
					 
					
						
						
							
							hw/sd/sdcard: Convert LOCK_UNLOCK to generic_write_byte (CMD42)  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-35-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						a182208e5d 
					 
					
						
						
							
							hw/sd/sdcard: Convert PROGRAM_CSD to generic_write_byte (CMD27)  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-34-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						dbccae20f7 
					 
					
						
						
							
							hw/sd/sdcard: Convert PROGRAM_CID to generic_write_byte (CMD26)  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org >
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-33-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						540c1832dd 
					 
					
						
						
							
							hw/sd/sdcard: Convert WRITE_SINGLE_BLOCK to generic_write_byte (CMD24)  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org >
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-32-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						dba4b37b38 
					 
					
						
						
							
							hw/sd/sdcard: Duplicate WRITE_SINGLE_BLOCK / WRITE_MULTIPLE_BLOCK cases  
						
						... 
						
						
						
						In order to modify the WRITE_SINGLE_BLOCK case in the
next commit, duplicate it first.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-31-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						740d51d1a3 
					 
					
						
						
							
							hw/sd/sdcard: Introduce sd_cmd_to_receivingdata / sd_generic_write_byte  
						
						... 
						
						
						
						All commands switching from TRANSFER state to (receiving)DATA
do the same: receive stream of data from the DAT lines. Instead
of duplicating the same code many times, introduce 2 helpers:
- sd_cmd_to_receivingdata() on the I/O line setup the data to
  be received on the data[] buffer,
- sd_generic_write_byte() on the DAT lines to push the data.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-30-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						a320f9c067 
					 
					
						
						
							
							hw/sd/sdcard: Convert SEND_SCR to generic_read_byte (ACMD51)  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org >
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-29-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						4d842275e2 
					 
					
						
						
							
							hw/sd/sdcard: Convert SEND_NUM_WR_BLOCKS to generic_read_byte (ACMD22)  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-28-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						ca24559d2c 
					 
					
						
						
							
							hw/sd/sdcard: Convert SD_STATUS to generic_read_byte (ACMD13)  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org >
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-27-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						2c67f8e707 
					 
					
						
						
							
							hw/sd/sdcard: Convert SEND_WRITE_PROT to generic_read_byte (CMD30)  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-25-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						060f0dac86 
					 
					
						
						
							
							hw/sd/sdcard: Convert SEND_TUNING_BLOCK to generic_read_byte (CMD19)  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org >
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-24-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						e7a73713f8 
					 
					
						
						
							
							hw/sd/sdcard: Convert READ_SINGLE_BLOCK to generic_read_byte (CMD17)  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org >
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-23-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						eef0d42995 
					 
					
						
						
							
							hw/sd/sdcard: Duplicate READ_SINGLE_BLOCK / READ_MULTIPLE_BLOCK cases  
						
						... 
						
						
						
						In order to modify the READ_SINGLE_BLOCK case in the
next commit, duplicate it first.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-22-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						374c93ecea 
					 
					
						
						
							
							hw/sd/sdcard: Convert SEND_CSD/SEND_CID to generic_read_byte (CMD9 & 10)  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org >
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-21-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						1544e9f41d 
					 
					
						
						
							
							hw/sd/sdcard: Convert SWITCH_FUNCTION to generic_read_byte (CMD6)  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-20-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						f486bf7d10 
					 
					
						
						
							
							hw/sd/sdcard: Introduce sd_cmd_to_sendingdata and sd_generic_read_byte  
						
						... 
						
						
						
						All commands switching from TRANSFER state to (sending)DATA
do the same: send stream of data on the DAT lines. Instead
of duplicating the same code many times, introduce 2 helpers:
- sd_cmd_to_sendingdata() on the I/O line setup the data to
  be transferred,
- sd_generic_read_byte() on the DAT lines to fetch the data.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <4c9f7f51-83ee-421a-8690-9af2e80b134b@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						cb49e2ca22 
					 
					
						
						
							
							hw/sd/sdcard: Extract sd_blk_len() helper  
						
						... 
						
						
						
						Extract sd_blk_len() helper, use definitions instead
of magic values.
Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org >
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-15-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						12160bebd4 
					 
					
						
						
							
							hw/sd/sdcard: Add direct reference to SDProto in SDState  
						
						... 
						
						
						
						Keep direct reference to SDProto in SDState,
remove then unnecessary sd_proto().
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-14-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						257e36c9e6 
					 
					
						
						
							
							hw/sd/sdcard: Simplify sd_inactive_state handling  
						
						... 
						
						
						
						Card entering sd_inactive_state powers off, and won't respond
anymore. Handle that once when entering sd_do_command().
Remove condition always true in sd_cmd_GO_IDLE_STATE().
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-12-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						26be1ceee5 
					 
					
						
						
							
							hw/sd/sdcard: Assign SDCardStates enum values  
						
						... 
						
						
						
						SDCardStates enum values are specified, so assign them
correspondingly. It will be useful later when we add
states from later specs, which might not be continuous.
See CURRENT_STATE bits in section 4.10.1 "Card Status".
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-11-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						854f5bc655 
					 
					
						
						
							
							hw/sd/sdcard: Use READY_FOR_DATA definition instead of magic value  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-10-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:32 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						7028187bd0 
					 
					
						
						
							
							hw/sd/sdcard: Send NUM_WR_BLOCKS bits MSB first (ACMD22)  
						
						... 
						
						
						
						Per sections 3.6.1 (SD Bus Protocol), 4.3.4 "Data Write"
and 7.3.2 (Responses):
  In the CMD line the Most Significant Bit is transmitted first.
Use the stl_be_p() helper to store the value in big-endian.
Fixes: a1bb27b1e9philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20240628070216.92609-9-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:28 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						e55cbe727b 
					 
					
						
						
							
							hw/sd/sdcard: Send WRITE_PROT bits MSB first (CMD30)  
						
						... 
						
						
						
						Per sections 3.6.1 (SD Bus Protocol) and 7.3.2 (Responses):
  In the CMD line the Most Significant Bit is transmitted first.
Use the stl_be_p() helper to store the value in big-endian.
Fixes: a1bb27b1e9philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Peter Maydell <peter.maydell@linaro.org >
Message-Id: <20240628070216.92609-8-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:08:24 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						c239084f5b 
					 
					
						
						
							
							hw/sd/sdcard: Restrict SWITCH_FUNCTION to sd_transfer_state (CMD6)  
						
						... 
						
						
						
						SWITCH_FUNCTION is only allowed in TRANSFER state
(See 4.8 "Card State Transition Table).
Fixes: a1bb27b1e9philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-13-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 10:07:48 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						2ec83d679e 
					 
					
						
						
							
							hw/sd/sdcard: Trace requested address computed by sd_req_get_address()  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Luc Michel <luc.michel@amd.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-6-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 09:20:36 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						c159de66f2 
					 
					
						
						
							
							hw/sd/sdcard: Trace block offset in READ/WRITE data accesses  
						
						... 
						
						
						
						Useful to detect out of bound accesses.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Tested-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-5-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 09:19:20 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						702ff29c8f 
					 
					
						
						
							
							hw/sd/sdcard: Track last command used to help logging  
						
						... 
						
						
						
						The command is selected on the I/O lines, and further
processing might be done on the DAT lines via the
sd_read_byte() and sd_write_byte() handlers. Since
these methods can't distinct between normal and APP
commands, keep the name of the current command in
the SDState and use it in the DAT handlers. This
fixes a bug that all normal commands were displayed
as APP commands.
Fixes: 2ed61fb57bphilmd@linaro.org >
Tested-by: Cédric Le Goater <clg@redhat.com >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240628070216.92609-4-philmd@linaro.org > 
						
						
					 
					
						2024-07-02 09:19:20 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						76ae9a2314 
					 
					
						
						
							
							hw/sd/sdcard: Add comments around registers and commands  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org >
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Tested-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240621080554.18986-21-philmd@linaro.org > 
						
						
					 
					
						2024-06-24 15:08:40 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						cd44ccee18 
					 
					
						
						
							
							hw/sd/sdcard: Inline BLK_READ_BLOCK / BLK_WRITE_BLOCK macros  
						
						... 
						
						
						
						These macros only save 3 chars and make the code harder
to maintain, simply remove them.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Tested-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240621080554.18986-20-philmd@linaro.org > 
						
						
					 
					
						2024-06-24 15:08:39 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						9ee9292b75 
					 
					
						
						
							
							hw/sd/sdcard: Add sd_invalid_mode_for_cmd to report invalid mode switch  
						
						... 
						
						
						
						Having the mode switch displayed help to track incomplete
command implementations.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Tested-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240621080554.18986-19-philmd@linaro.org > 
						
						
					 
					
						2024-06-24 10:41:42 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						6a226b2cab 
					 
					
						
						
							
							hw/sd/sdcard: Only call sd_req_get_address() where address is used  
						
						... 
						
						
						
						It will be useful later to assert only ADTC commands
(Addressed point-to-point Data Transfer Commands, defined
as the 'sd_adtc' enum) extract the address value from the
command argument.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Tested-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240621080554.18986-18-philmd@linaro.org > 
						
						
					 
					
						2024-06-24 10:41:42 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						8b91a5613c 
					 
					
						
						
							
							hw/sd/sdcard: Factor sd_req_get_address() method out  
						
						... 
						
						
						
						Extract sd_cmd_get_address() so we can re-use it
in various SDProto handlers. Use CARD_CAPACITY and
HWBLOCK_SHIFT definitions instead of magic values.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Tested-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240621080554.18986-17-philmd@linaro.org > 
						
						
					 
					
						2024-06-24 10:41:42 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						4a829730c8 
					 
					
						
						
							
							hw/sd/sdcard: Only call sd_req_get_rca() where RCA is used  
						
						... 
						
						
						
						It will be useful later to assert only AC commands
(Addressed point-to-point Commands, defined as the
'sd_ac' enum) extract the RCA value from the command
argument.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Tested-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240621080554.18986-16-philmd@linaro.org > 
						
						
					 
					
						2024-06-24 10:41:42 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						0ab318ca3c 
					 
					
						
						
							
							hw/sd/sdcard: Factor sd_req_get_rca() method out  
						
						... 
						
						
						
						Extract sd_req_get_rca() so we can re-use it in various
SDProto handlers. Return a 16-bit value since RCA is 16-bit.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Tested-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240621080554.18986-15-philmd@linaro.org > 
						
						
					 
					
						2024-06-24 10:41:42 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						eded0d1a48 
					 
					
						
						
							
							hw/sd/sdcard: Have cmd_valid_while_locked() return a boolean value  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Tested-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240621080554.18986-14-philmd@linaro.org > 
						
						
					 
					
						2024-06-24 10:41:42 +02:00 
						 
				 
			
				
					
						
							
							
								Philippe Mathieu-Daudé 
							
						 
					 
					
						
						
							
						
						0e93b3b30b 
					 
					
						
						
							
							hw/sd/sdcard: Trace update of block count (CMD23)  
						
						... 
						
						
						
						Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org >
Reviewed-by: Cédric Le Goater <clg@redhat.com >
Tested-by: Cédric Le Goater <clg@redhat.com >
Message-Id: <20240621080554.18986-12-philmd@linaro.org > 
						
						
					 
					
						2024-06-24 10:41:42 +02:00