mirror of
https://github.com/edk2-porting/linux-next.git
synced 2024-12-20 11:13:58 +08:00
mmc: block: fix packed command header endianness
The code that fills packed command header assumes that CPU runs in
little-endian mode. Hence the header is malformed in big-endian mode
and causes MMC data transfer errors:
[ 563.200828] mmcblk0: error -110 transferring data, sector 2048, nr 8, cmd response 0x900, card status 0xc40
[ 563.219647] mmcblk0: packed cmd failed, nr 2, sectors 16, failure index: -1
Convert header data to LE.
Signed-off-by: Taras Kondratiuk <takondra@cisco.com>
Fixes: ce39f9d17c
("mmc: support packed write command for eMMC4.5 devices")
Cc: <stable@vger.kernel.org>
Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
This commit is contained in:
parent
bfe5b1b1e0
commit
f68381a70b
@ -1788,8 +1788,8 @@ static void mmc_blk_packed_hdr_wrq_prep(struct mmc_queue_req *mqrq,
|
|||||||
|
|
||||||
packed_cmd_hdr = packed->cmd_hdr;
|
packed_cmd_hdr = packed->cmd_hdr;
|
||||||
memset(packed_cmd_hdr, 0, sizeof(packed->cmd_hdr));
|
memset(packed_cmd_hdr, 0, sizeof(packed->cmd_hdr));
|
||||||
packed_cmd_hdr[0] = (packed->nr_entries << 16) |
|
packed_cmd_hdr[0] = cpu_to_le32((packed->nr_entries << 16) |
|
||||||
(PACKED_CMD_WR << 8) | PACKED_CMD_VER;
|
(PACKED_CMD_WR << 8) | PACKED_CMD_VER);
|
||||||
hdr_blocks = mmc_large_sector(card) ? 8 : 1;
|
hdr_blocks = mmc_large_sector(card) ? 8 : 1;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -1803,14 +1803,14 @@ static void mmc_blk_packed_hdr_wrq_prep(struct mmc_queue_req *mqrq,
|
|||||||
((brq->data.blocks * brq->data.blksz) >=
|
((brq->data.blocks * brq->data.blksz) >=
|
||||||
card->ext_csd.data_tag_unit_size);
|
card->ext_csd.data_tag_unit_size);
|
||||||
/* Argument of CMD23 */
|
/* Argument of CMD23 */
|
||||||
packed_cmd_hdr[(i * 2)] =
|
packed_cmd_hdr[(i * 2)] = cpu_to_le32(
|
||||||
(do_rel_wr ? MMC_CMD23_ARG_REL_WR : 0) |
|
(do_rel_wr ? MMC_CMD23_ARG_REL_WR : 0) |
|
||||||
(do_data_tag ? MMC_CMD23_ARG_TAG_REQ : 0) |
|
(do_data_tag ? MMC_CMD23_ARG_TAG_REQ : 0) |
|
||||||
blk_rq_sectors(prq);
|
blk_rq_sectors(prq));
|
||||||
/* Argument of CMD18 or CMD25 */
|
/* Argument of CMD18 or CMD25 */
|
||||||
packed_cmd_hdr[((i * 2)) + 1] =
|
packed_cmd_hdr[((i * 2)) + 1] = cpu_to_le32(
|
||||||
mmc_card_blockaddr(card) ?
|
mmc_card_blockaddr(card) ?
|
||||||
blk_rq_pos(prq) : blk_rq_pos(prq) << 9;
|
blk_rq_pos(prq) : blk_rq_pos(prq) << 9);
|
||||||
packed->blocks += blk_rq_sectors(prq);
|
packed->blocks += blk_rq_sectors(prq);
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user