Skip to content

Commit 3241a61

Browse files
committed
hw/sd/sdcard: Use complete SEND_OP_COND implementation in SPI mode
While spi_cmd_SEND_OP_COND() is incomplete, sd_cmd_SEND_OP_COND() is, except it doesn't return the correct value in SPI mode. Correct and use, removing the need for spi_cmd_SEND_OP_COND(). Fixes: 775616c ("Partial SD card SPI mode support") Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org> Acked-by: Richard Henderson <richard.henderson@linaro.org> Message-Id: <20250804133406.17456-7-philmd@linaro.org>
1 parent 0f2ff99 commit 3241a61

File tree

1 file changed

+5
-10
lines changed

1 file changed

+5
-10
lines changed

hw/sd/sd.c

Lines changed: 5 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -1414,14 +1414,6 @@ static sd_rsp_type_t sd_cmd_GO_IDLE_STATE(SDState *sd, SDRequest req)
14141414
return sd_is_spi(sd) ? sd_r1 : sd_r0;
14151415
}
14161416

1417-
/* CMD1 */
1418-
static sd_rsp_type_t spi_cmd_SEND_OP_COND(SDState *sd, SDRequest req)
1419-
{
1420-
sd->state = sd_transfer_state;
1421-
1422-
return sd_r1;
1423-
}
1424-
14251417
/* CMD2 */
14261418
static sd_rsp_type_t sd_cmd_ALL_SEND_CID(SDState *sd, SDRequest req)
14271419
{
@@ -2046,6 +2038,9 @@ static sd_rsp_type_t sd_cmd_SEND_OP_COND(SDState *sd, SDRequest req)
20462038
sd->state = sd_ready_state;
20472039
}
20482040

2041+
if (sd_is_spi(sd)) {
2042+
return sd_r1;
2043+
}
20492044
return sd_r3;
20502045
}
20512046

@@ -2590,7 +2585,7 @@ static const SDProto sd_proto_spi = {
25902585
.name = "SPI",
25912586
.cmd = {
25922587
[0] = {0, sd_spi, "GO_IDLE_STATE", sd_cmd_GO_IDLE_STATE},
2593-
[1] = {0, sd_spi, "SEND_OP_COND", spi_cmd_SEND_OP_COND},
2588+
[1] = {0, sd_spi, "SEND_OP_COND", sd_cmd_SEND_OP_COND},
25942589
[5] = {9, sd_spi, "IO_SEND_OP_COND", sd_cmd_optional},
25952590
[6] = {10, sd_spi, "SWITCH_FUNCTION", sd_cmd_SWITCH_FUNCTION},
25962591
[8] = {0, sd_spi, "SEND_IF_COND", sd_cmd_SEND_IF_COND},
@@ -2626,7 +2621,7 @@ static const SDProto sd_proto_spi = {
26262621
[13] = {8, sd_spi, "SD_STATUS", sd_acmd_SD_STATUS},
26272622
[22] = {8, sd_spi, "SEND_NUM_WR_BLOCKS", sd_acmd_SEND_NUM_WR_BLOCKS},
26282623
[23] = {8, sd_spi, "SET_WR_BLK_ERASE_COUNT", sd_acmd_SET_WR_BLK_ERASE_COUNT},
2629-
[41] = {8, sd_spi, "SEND_OP_COND", spi_cmd_SEND_OP_COND},
2624+
[41] = {8, sd_spi, "SEND_OP_COND", sd_cmd_SEND_OP_COND},
26302625
[42] = {8, sd_spi, "SET_CLR_CARD_DETECT", sd_acmd_SET_CLR_CARD_DETECT},
26312626
[51] = {8, sd_spi, "SEND_SCR", sd_acmd_SEND_SCR},
26322627
},

0 commit comments

Comments
 (0)