84 lines
2.8 KiB
Diff
84 lines
2.8 KiB
Diff
|
From: Bin Meng <bin.meng@windriver.com>
|
||
|
Date: Tue, 16 Feb 2021 23:02:21 +0800
|
||
|
Subject: hw/sd: sd: Move the sd_block_{read, write} and macros ahead
|
||
|
MIME-Version: 1.0
|
||
|
Content-Type: text/plain; charset=UTF-8
|
||
|
Content-Transfer-Encoding: 8bit
|
||
|
|
||
|
Git-commit: ce6ea2efc5fb308ebf11339276f60215fe0ec44c
|
||
|
References: bsc#1175144, CVE-2020-17380, bsc#1176681, CVE-2020-25085
|
||
|
References: bsc#1182282, CVE-2021-3409
|
||
|
|
||
|
These APIs and macros may be referenced by functions that are
|
||
|
currently before them. Move them ahead a little bit.
|
||
|
|
||
|
Signed-off-by: Bin Meng <bin.meng@windriver.com>
|
||
|
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
|
||
|
Message-Id: <20210216150225.27996-5-bmeng.cn@gmail.com>
|
||
|
Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
|
||
|
Signed-off-by: Bruce Rogers <brogers@suse.com>
|
||
|
---
|
||
|
hw/sd/sd.c | 42 +++++++++++++++++++++---------------------
|
||
|
1 file changed, 21 insertions(+), 21 deletions(-)
|
||
|
|
||
|
diff --git a/hw/sd/sd.c b/hw/sd/sd.c
|
||
|
index 5cdcd54cfcbf467342b2e485ac3e..ac48140251de7845a01ab4ad656c 100644
|
||
|
--- a/hw/sd/sd.c
|
||
|
+++ b/hw/sd/sd.c
|
||
|
@@ -755,6 +755,27 @@ void sd_set_cb(SDState *sd, qemu_irq readonly, qemu_irq insert)
|
||
|
qemu_set_irq(insert, sd->blk ? blk_is_inserted(sd->blk) : 0);
|
||
|
}
|
||
|
|
||
|
+static void sd_blk_read(SDState *sd, uint64_t addr, uint32_t len)
|
||
|
+{
|
||
|
+ trace_sdcard_read_block(addr, len);
|
||
|
+ if (!sd->blk || blk_pread(sd->blk, addr, sd->data, len) < 0) {
|
||
|
+ fprintf(stderr, "sd_blk_read: read error on host side\n");
|
||
|
+ }
|
||
|
+}
|
||
|
+
|
||
|
+static void sd_blk_write(SDState *sd, uint64_t addr, uint32_t len)
|
||
|
+{
|
||
|
+ trace_sdcard_write_block(addr, len);
|
||
|
+ if (!sd->blk || blk_pwrite(sd->blk, addr, sd->data, len, 0) < 0) {
|
||
|
+ fprintf(stderr, "sd_blk_write: write error on host side\n");
|
||
|
+ }
|
||
|
+}
|
||
|
+
|
||
|
+#define BLK_READ_BLOCK(a, len) sd_blk_read(sd, a, len)
|
||
|
+#define BLK_WRITE_BLOCK(a, len) sd_blk_write(sd, a, len)
|
||
|
+#define APP_READ_BLOCK(a, len) memset(sd->data, 0xec, len)
|
||
|
+#define APP_WRITE_BLOCK(a, len)
|
||
|
+
|
||
|
static void sd_erase(SDState *sd)
|
||
|
{
|
||
|
int i;
|
||
|
@@ -1815,27 +1836,6 @@ send_response:
|
||
|
return rsplen;
|
||
|
}
|
||
|
|
||
|
-static void sd_blk_read(SDState *sd, uint64_t addr, uint32_t len)
|
||
|
-{
|
||
|
- trace_sdcard_read_block(addr, len);
|
||
|
- if (!sd->blk || blk_pread(sd->blk, addr, sd->data, len) < 0) {
|
||
|
- fprintf(stderr, "sd_blk_read: read error on host side\n");
|
||
|
- }
|
||
|
-}
|
||
|
-
|
||
|
-static void sd_blk_write(SDState *sd, uint64_t addr, uint32_t len)
|
||
|
-{
|
||
|
- trace_sdcard_write_block(addr, len);
|
||
|
- if (!sd->blk || blk_pwrite(sd->blk, addr, sd->data, len, 0) < 0) {
|
||
|
- fprintf(stderr, "sd_blk_write: write error on host side\n");
|
||
|
- }
|
||
|
-}
|
||
|
-
|
||
|
-#define BLK_READ_BLOCK(a, len) sd_blk_read(sd, a, len)
|
||
|
-#define BLK_WRITE_BLOCK(a, len) sd_blk_write(sd, a, len)
|
||
|
-#define APP_READ_BLOCK(a, len) memset(sd->data, 0xec, len)
|
||
|
-#define APP_WRITE_BLOCK(a, len)
|
||
|
-
|
||
|
void sd_write_byte(SDState *sd, uint8_t value)
|
||
|
{
|
||
|
int i;
|