aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAvri Altman <avri.altman@wdc.com>2023-06-25 13:38:09 +0300
committerUlf Hansson <ulf.hansson@linaro.org>2023-08-07 13:08:21 +0200
commit731a1cca552cdb85da9df5d8ffdfb2045870aef3 (patch)
tree202000e2c7c3588002c6aa59b1674244ef39a892
parent6d593efc3cd00e4debd0ffc5806246390dc66242 (diff)
downloadmmc-utils-731a1cca552cdb85da9df5d8ffdfb2045870aef3.tar.gz
mmc-utils: Add fill_switch_cmd handler
Writing the ext_csd (MMC_SWITCH) is done in several places throught the code. Prepare a single handler for that. This patch has no functional change. Signed-off-by: Avri Altman <avri.altman@wdc.com> Link: https://lore.kernel.org/r/20230625103814.105-2-avri.altman@wdc.com Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
-rw-r--r--mmc_cmds.c50
1 files changed, 18 insertions, 32 deletions
diff --git a/mmc_cmds.c b/mmc_cmds.c
index 26bdc38..da89724 100644
--- a/mmc_cmds.c
+++ b/mmc_cmds.c
@@ -79,19 +79,22 @@ int read_extcsd(int fd, __u8 *ext_csd)
return ret;
}
+static void fill_switch_cmd(struct mmc_ioc_cmd *cmd, __u8 index, __u8 value)
+{
+ cmd->opcode = MMC_SWITCH;
+ cmd->write_flag = 1;
+ cmd->arg = (MMC_SWITCH_MODE_WRITE_BYTE << 24) | (index << 16) |
+ (value << 8) | EXT_CSD_CMD_SET_NORMAL;
+ cmd->flags = MMC_RSP_SPI_R1B | MMC_RSP_R1B | MMC_CMD_AC;
+}
+
int write_extcsd_value(int fd, __u8 index, __u8 value, unsigned int timeout_ms)
{
int ret = 0;
- struct mmc_ioc_cmd idata;
+ struct mmc_ioc_cmd idata = {};
+
+ fill_switch_cmd(&idata, index, value);
- memset(&idata, 0, sizeof(idata));
- idata.write_flag = 1;
- idata.opcode = MMC_SWITCH;
- idata.arg = (MMC_SWITCH_MODE_WRITE_BYTE << 24) |
- (index << 16) |
- (value << 8) |
- EXT_CSD_CMD_SET_NORMAL;
- idata.flags = MMC_RSP_SPI_R1B | MMC_RSP_R1B | MMC_CMD_AC;
/* Kernel will set cmd_timeout_ms if 0 is set */
idata.cmd_timeout_ms = timeout_ms;
@@ -2887,13 +2890,8 @@ int do_ffu(int nargs, char **argv)
multi_cmd->num_of_cmds = 4;
/* put device into ffu mode */
- multi_cmd->cmds[0].opcode = MMC_SWITCH;
- multi_cmd->cmds[0].arg = (MMC_SWITCH_MODE_WRITE_BYTE << 24) |
- (EXT_CSD_MODE_CONFIG << 16) |
- (EXT_CSD_FFU_MODE << 8) |
- EXT_CSD_CMD_SET_NORMAL;
- multi_cmd->cmds[0].flags = MMC_RSP_SPI_R1B | MMC_RSP_R1B | MMC_CMD_AC;
- multi_cmd->cmds[0].write_flag = 1;
+ fill_switch_cmd(&multi_cmd->cmds[0], EXT_CSD_MODE_CONFIG,
+ EXT_CSD_FFU_MODE);
/* send block count */
multi_cmd->cmds[1].opcode = MMC_SET_BLOCK_COUNT;
@@ -2914,13 +2912,8 @@ int do_ffu(int nargs, char **argv)
mmc_ioc_cmd_set_data(multi_cmd->cmds[2], buf);
/* return device into normal mode */
- multi_cmd->cmds[3].opcode = MMC_SWITCH;
- multi_cmd->cmds[3].arg = (MMC_SWITCH_MODE_WRITE_BYTE << 24) |
- (EXT_CSD_MODE_CONFIG << 16) |
- (EXT_CSD_NORMAL_MODE << 8) |
- EXT_CSD_CMD_SET_NORMAL;
- multi_cmd->cmds[3].flags = MMC_RSP_SPI_R1B | MMC_RSP_R1B | MMC_CMD_AC;
- multi_cmd->cmds[3].write_flag = 1;
+ fill_switch_cmd(&multi_cmd->cmds[3], EXT_CSD_MODE_CONFIG,
+ EXT_CSD_NORMAL_MODE);
/* read firmware */
lseek(img_fd, 0, SEEK_SET);
@@ -2986,15 +2979,8 @@ do_retry:
multi_cmd->num_of_cmds = 2;
/* set ext_csd to install mode */
- multi_cmd->cmds[1].opcode = MMC_SWITCH;
- multi_cmd->cmds[1].blksz = 0;
- multi_cmd->cmds[1].blocks = 0;
- multi_cmd->cmds[1].arg = (MMC_SWITCH_MODE_WRITE_BYTE << 24) |
- (EXT_CSD_MODE_OPERATION_CODES << 16) |
- (EXT_CSD_FFU_INSTALL << 8) |
- EXT_CSD_CMD_SET_NORMAL;
- multi_cmd->cmds[1].flags = MMC_RSP_SPI_R1B | MMC_RSP_R1B | MMC_CMD_AC;
- multi_cmd->cmds[1].write_flag = 1;
+ fill_switch_cmd(&multi_cmd->cmds[1], EXT_CSD_MODE_OPERATION_CODES,
+ EXT_CSD_FFU_INSTALL);
/* send ioctl with multi-cmd */
ret = ioctl(dev_fd, MMC_IOC_MULTI_CMD, multi_cmd);