[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH v3 41/42] sdhci: add a check_capab_v3() qtest
From: |
Philippe Mathieu-Daudé |
Subject: |
[Qemu-devel] [PATCH v3 41/42] sdhci: add a check_capab_v3() qtest |
Date: |
Fri, 29 Dec 2017 14:49:32 -0300 |
Signed-off-by: Philippe Mathieu-Daudé <address@hidden>
Reviewed-by: Stefan Hajnoczi <address@hidden>
---
tests/sdhci-test.c | 18 ++++++++++++++++++
1 file changed, 18 insertions(+)
diff --git a/tests/sdhci-test.c b/tests/sdhci-test.c
index 91b1b29d75..6ebe9f4d25 100644
--- a/tests/sdhci-test.c
+++ b/tests/sdhci-test.c
@@ -13,6 +13,8 @@
#define SDHC_CAPAB 0x40
FIELD(SDHC_CAPAB, BASECLKFREQ, 8, 8); /* since v2 */
FIELD(SDHC_CAPAB, SDMA, 22, 1);
+FIELD(SDHC_CAPAB, SDR, 32, 3); /* since v3 */
+FIELD(SDHC_CAPAB, DRIVER, 36, 3); /* since v3 */
#define SDHC_HCVER 0xFE
static const struct sdhci_t {
@@ -123,6 +125,21 @@ static void check_capab_sdma(uintptr_t addr, bool
supported)
g_assert_cmpuint(capab_sdma, ==, supported);
}
+static void check_capab_v3(uintptr_t addr, uint8_t version)
+{
+ uint64_t capab, capab_v3;
+
+ if (version >= 3) {
+ return;
+ }
+ /* before v3 those fields are RESERVED */
+ capab = sdhci_readq(addr, SDHC_CAPAB);
+ capab_v3 = FIELD_EX64(capab, SDHC_CAPAB, SDR);
+ g_assert_cmpuint(capab_v3, ==, 0);
+ capab_v3 = FIELD_EX64(capab, SDHC_CAPAB, DRIVER);
+ g_assert_cmpuint(capab_v3, ==, 0);
+}
+
static void test_machine(const void *data)
{
const struct sdhci_t *test = data;
@@ -132,6 +149,7 @@ static void test_machine(const void *data)
check_capab_capareg(test->sdhci.addr, test->sdhci.capab.reg);
check_specs_version(test->sdhci.addr, test->sdhci.version);
check_capab_readonly(test->sdhci.addr);
+ check_capab_v3(test->sdhci.addr, test->sdhci.version);
check_capab_sdma(test->sdhci.addr, test->sdhci.capab.sdma);
check_capab_baseclock(test->sdhci.addr, test->sdhci.baseclock);
--
2.15.1
- [Qemu-devel] [PATCH v3 29/42] sdhci: add qtest to check the SD Spec version, (continued)
- [Qemu-devel] [PATCH v3 29/42] sdhci: add qtest to check the SD Spec version, Philippe Mathieu-Daudé, 2017/12/29
- [Qemu-devel] [PATCH v3 30/42] sdhci: check Spec v2 capabilities qtest, Philippe Mathieu-Daudé, 2017/12/29
- [Qemu-devel] [PATCH v3 32/42] sdhci: rename the hostctl1 register, Philippe Mathieu-Daudé, 2017/12/29
- [Qemu-devel] [PATCH v3 33/42] hw/arm/bcm2835_peripherals: implement SDHCI Spec v3, Philippe Mathieu-Daudé, 2017/12/29
- [Qemu-devel] [PATCH v3 34/42] hw/arm/fsl-imx6: implement SDHCI Spec v3, Philippe Mathieu-Daudé, 2017/12/29
- [Qemu-devel] [PATCH v3 35/42] hw/arm/xilinx_zynqmp: implement SDHCI Spec v3, Philippe Mathieu-Daudé, 2017/12/29
- [Qemu-devel] [PATCH v3 36/42] sdhci: check Spec v3 capabilities qtest, Philippe Mathieu-Daudé, 2017/12/29
- [Qemu-devel] [PATCH v3 37/42] sdhci: remove the deprecated 'capareg' property, Philippe Mathieu-Daudé, 2017/12/29
- [Qemu-devel] [PATCH v3 39/42] sdhci: add a check_capab_baseclock() qtest, Philippe Mathieu-Daudé, 2017/12/29
- [Qemu-devel] [PATCH v3 38/42] sdhci: add check_capab_readonly() qtest, Philippe Mathieu-Daudé, 2017/12/29
- [Qemu-devel] [PATCH v3 41/42] sdhci: add a check_capab_v3() qtest,
Philippe Mathieu-Daudé <=
- [Qemu-devel] [PATCH v3 40/42] sdhci: add a check_capab_sdma() qtest, Philippe Mathieu-Daudé, 2017/12/29
- [Qemu-devel] [PATCH v3 42/42] sdhci: add Spec v4.2 register definitions, Philippe Mathieu-Daudé, 2017/12/29