aboutsummaryrefslogtreecommitdiff
path: root/tests/qtest/ast2700-gpio-test.c
blob: eeae9bf11fc27fa08b3c2085e4ae3a30d9f82930 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
/*
 * QTest testcase for the ASPEED AST2700 GPIO Controller.
 *
 * SPDX-License-Identifier: GPL-2.0-or-later
 * Copyright (C) 2024 ASPEED Technology Inc.
 */

#include "qemu/osdep.h"
#include "qemu/bitops.h"
#include "qemu/timer.h"
#include "qobject/qdict.h"
#include "libqtest-single.h"

#define AST2700_GPIO_BASE 0x14C0B000
#define GPIOA0_CONTROL 0x180

static void test_output_pins(const char *machine, const uint32_t base)
{
    QTestState *s = qtest_init(machine);
    uint32_t offset = 0;
    uint32_t value = 0;
    uint32_t pin = 0;

    for (char c = 'A'; c <= 'D'; c++) {
        for (int i = 0; i < 8; i++) {
            offset = base + (pin * 4);

            /* output direction and output hi */
            qtest_writel(s, offset, 0x00000003);
            value = qtest_readl(s, offset);
            g_assert_cmphex(value, ==, 0x00000003);

            /* output direction and output low */
            qtest_writel(s, offset, 0x00000002);
            value = qtest_readl(s, offset);
            g_assert_cmphex(value, ==, 0x00000002);
            pin++;
        }
    }

    qtest_quit(s);
}

static void test_input_pins(const char *machine, const uint32_t base)
{
    QTestState *s = qtest_init(machine);
    char name[16];
    uint32_t offset = 0;
    uint32_t value = 0;
    uint32_t pin = 0;

    for (char c = 'A'; c <= 'D'; c++) {
        for (int i = 0; i < 8; i++) {
            sprintf(name, "gpio%c%d", c, i);
            offset = base + (pin * 4);
            /* input direction */
            qtest_writel(s, offset, 0);

            /* set input */
            qtest_qom_set_bool(s, "/machine/soc/gpio", name, true);
            value = qtest_readl(s, offset);
            g_assert_cmphex(value, ==, 0x00002000);

            /* clear input */
            qtest_qom_set_bool(s, "/machine/soc/gpio", name, false);
            value = qtest_readl(s, offset);
            g_assert_cmphex(value, ==, 0);
            pin++;
        }
    }

    qtest_quit(s);
}

static void test_2700_input_pins(void)
{
    test_input_pins("-machine ast2700-evb",
                    AST2700_GPIO_BASE + GPIOA0_CONTROL);
}

static void test_2700_output_pins(void)
{
    test_output_pins("-machine ast2700-evb",
                     AST2700_GPIO_BASE + GPIOA0_CONTROL);
}

int main(int argc, char **argv)
{
    g_test_init(&argc, &argv, NULL);

    qtest_add_func("/ast2700/gpio/input_pins", test_2700_input_pins);
    qtest_add_func("/ast2700/gpio/output_pins", test_2700_output_pins);

    return g_test_run();
}