|
@@ -819,6 +819,15 @@ static GPIOSetProperties ast2600_1_8v_set_props[ASPEED_GPIO_MAX_NR_SETS] = {
|
|
[1] = {0x0000000f, 0x0000000f, {"18E"} },
|
|
[1] = {0x0000000f, 0x0000000f, {"18E"} },
|
|
};
|
|
};
|
|
|
|
|
|
|
|
+static GPIOSetProperties ast1030_set_props[ASPEED_GPIO_MAX_NR_SETS] = {
|
|
|
|
+ [0] = {0xffffffff, 0xffffffff, {"A", "B", "C", "D"} },
|
|
|
|
+ [1] = {0xffffffff, 0xffffffff, {"E", "F", "G", "H"} },
|
|
|
|
+ [2] = {0xffffffff, 0xffffffff, {"I", "J", "K", "L"} },
|
|
|
|
+ [3] = {0xffffff3f, 0xffffff3f, {"M", "N", "O", "P"} },
|
|
|
|
+ [4] = {0xff060c1f, 0x00060c1f, {"Q", "R", "S", "T"} },
|
|
|
|
+ [5] = {0x000000ff, 0x00000000, {"U"} },
|
|
|
|
+};
|
|
|
|
+
|
|
static const MemoryRegionOps aspeed_gpio_ops = {
|
|
static const MemoryRegionOps aspeed_gpio_ops = {
|
|
.read = aspeed_gpio_read,
|
|
.read = aspeed_gpio_read,
|
|
.write = aspeed_gpio_write,
|
|
.write = aspeed_gpio_write,
|
|
@@ -971,6 +980,16 @@ static void aspeed_gpio_ast2600_1_8v_class_init(ObjectClass *klass, void *data)
|
|
agc->reg_table = aspeed_1_8v_gpios;
|
|
agc->reg_table = aspeed_1_8v_gpios;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+static void aspeed_gpio_1030_class_init(ObjectClass *klass, void *data)
|
|
|
|
+{
|
|
|
|
+ AspeedGPIOClass *agc = ASPEED_GPIO_CLASS(klass);
|
|
|
|
+
|
|
|
|
+ agc->props = ast1030_set_props;
|
|
|
|
+ agc->nr_gpio_pins = 151;
|
|
|
|
+ agc->nr_gpio_sets = 6;
|
|
|
|
+ agc->reg_table = aspeed_3_3v_gpios;
|
|
|
|
+}
|
|
|
|
+
|
|
static const TypeInfo aspeed_gpio_info = {
|
|
static const TypeInfo aspeed_gpio_info = {
|
|
.name = TYPE_ASPEED_GPIO,
|
|
.name = TYPE_ASPEED_GPIO,
|
|
.parent = TYPE_SYS_BUS_DEVICE,
|
|
.parent = TYPE_SYS_BUS_DEVICE,
|
|
@@ -1008,6 +1027,13 @@ static const TypeInfo aspeed_gpio_ast2600_1_8v_info = {
|
|
.instance_init = aspeed_gpio_init,
|
|
.instance_init = aspeed_gpio_init,
|
|
};
|
|
};
|
|
|
|
|
|
|
|
+static const TypeInfo aspeed_gpio_ast1030_info = {
|
|
|
|
+ .name = TYPE_ASPEED_GPIO "-ast1030",
|
|
|
|
+ .parent = TYPE_ASPEED_GPIO,
|
|
|
|
+ .class_init = aspeed_gpio_1030_class_init,
|
|
|
|
+ .instance_init = aspeed_gpio_init,
|
|
|
|
+};
|
|
|
|
+
|
|
static void aspeed_gpio_register_types(void)
|
|
static void aspeed_gpio_register_types(void)
|
|
{
|
|
{
|
|
type_register_static(&aspeed_gpio_info);
|
|
type_register_static(&aspeed_gpio_info);
|
|
@@ -1015,6 +1041,7 @@ static void aspeed_gpio_register_types(void)
|
|
type_register_static(&aspeed_gpio_ast2500_info);
|
|
type_register_static(&aspeed_gpio_ast2500_info);
|
|
type_register_static(&aspeed_gpio_ast2600_3_3v_info);
|
|
type_register_static(&aspeed_gpio_ast2600_3_3v_info);
|
|
type_register_static(&aspeed_gpio_ast2600_1_8v_info);
|
|
type_register_static(&aspeed_gpio_ast2600_1_8v_info);
|
|
|
|
+ type_register_static(&aspeed_gpio_ast1030_info);
|
|
}
|
|
}
|
|
|
|
|
|
type_init(aspeed_gpio_register_types);
|
|
type_init(aspeed_gpio_register_types);
|