[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v2 07/13] hw/sd/sd: Allow for inverting polarities of presence an
From: |
Bernhard Beschow |
Subject: |
[PATCH v2 07/13] hw/sd/sd: Allow for inverting polarities of presence and write-protect GPIOs |
Date: |
Sat, 11 Jan 2025 19:37:05 +0100 |
Signed-off-by: Bernhard Beschow <shentey@gmail.com>
---
hw/sd/sd.c | 12 ++++++++----
1 file changed, 8 insertions(+), 4 deletions(-)
diff --git a/hw/sd/sd.c b/hw/sd/sd.c
index aa8d86e1af..a50e5c20c8 100644
--- a/hw/sd/sd.c
+++ b/hw/sd/sd.c
@@ -181,6 +181,8 @@ struct SDState {
qemu_irq inserted_cb;
QEMUTimer *ocr_power_timer;
bool enable;
+ bool readonly_active_low;
+ bool inserted_active_low;
uint8_t dat_lines;
bool cmd_line;
};
@@ -876,8 +878,8 @@ static void sd_reset(DeviceState *dev)
sd->cmd_line = true;
sd->multi_blk_cnt = 0;
- qemu_set_irq(sd->readonly_cb, sd_get_readonly(sd));
- qemu_set_irq(sd->inserted_cb, sd_get_inserted(sd));
+ qemu_set_irq(sd->readonly_cb, sd_get_readonly(sd) ^
sd->readonly_active_low);
+ qemu_set_irq(sd->inserted_cb, sd_get_inserted(sd) ^
sd->inserted_active_low);
}
static void sd_cardchange(void *opaque, bool load, Error **errp)
@@ -896,9 +898,9 @@ static void sd_cardchange(void *opaque, bool load, Error
**errp)
}
if (sd->me_no_qdev_me_kill_mammoth_with_rocks) {
- qemu_set_irq(sd->inserted_cb, inserted);
+ qemu_set_irq(sd->inserted_cb, inserted ^ sd->inserted_active_low);
if (inserted) {
- qemu_set_irq(sd->readonly_cb, readonly);
+ qemu_set_irq(sd->readonly_cb, readonly ^ sd->readonly_active_low);
}
} else {
sdbus = SD_BUS(qdev_get_parent_bus(dev));
@@ -2797,6 +2799,8 @@ static void emmc_realize(DeviceState *dev, Error **errp)
static const Property sdmmc_common_properties[] = {
DEFINE_PROP_DRIVE("drive", SDState, blk),
+ DEFINE_PROP_BOOL("cd-active-low", SDState, inserted_active_low, false),
+ DEFINE_PROP_BOOL("wp-active-low", SDState, readonly_active_low, false),
};
static const Property sd_properties[] = {
--
2.48.0
- [PATCH v2 00/13] i.MX and SDHCI improvements, Bernhard Beschow, 2025/01/11
- [PATCH v2 02/13] hw/char/imx_serial: Fix reset value of UFCR register, Bernhard Beschow, 2025/01/11
- [PATCH v2 01/13] hw/sd/sdhci: Set SDHC_NIS_DMA bit when appropriate, Bernhard Beschow, 2025/01/11
- [PATCH v2 03/13] hw/char/imx_serial: Update all state before restarting ageing timer, Bernhard Beschow, 2025/01/11
- [PATCH v2 04/13] hw/pci-host/designware: Expose MSI IRQ, Bernhard Beschow, 2025/01/11
- [PATCH v2 06/13] hw/sd/sd: Remove legacy sd_set_cb() in favor of GPIOs, Bernhard Beschow, 2025/01/11
- [PATCH v2 05/13] hw/gpio/imx_gpio: Don't clear input GPIO values upon reset, Bernhard Beschow, 2025/01/11
- [PATCH v2 07/13] hw/sd/sd: Allow for inverting polarities of presence and write-protect GPIOs,
Bernhard Beschow <=
- [PATCH v2 08/13] hw/char/imx_serial: Turn some DPRINTF() statements into trace events, Bernhard Beschow, 2025/01/11
- [PATCH v2 09/13] hw/timer/imx_gpt: Remove unused define, Bernhard Beschow, 2025/01/11
- [PATCH v2 10/13] tests/qtest/libqos: Reuse TYPE_IMX_I2C define, Bernhard Beschow, 2025/01/11
- [PATCH v2 11/13] hw/i2c/imx_i2c: Convert DPRINTF() to trace events, Bernhard Beschow, 2025/01/11
- [PATCH v2 12/13] hw/misc/imx6_src: Convert DPRINTF() to trace events, Bernhard Beschow, 2025/01/11
- [PATCH v2 13/13] hw/gpio/imx_gpio: Turn DPRINTF() into trace events, Bernhard Beschow, 2025/01/11