]> git.sur5r.net Git - u-boot/blobdiff - arch/arm/mach-rockchip/rk3368/syscon_rk3368.c
arm64: zynqmp: Enable ttcs for zc1751 dc5
[u-boot] / arch / arm / mach-rockchip / rk3368 / syscon_rk3368.c
index 03e97eb6292f21554091887b0d782e5ea8a9b0ad..99d51f0edc0ff431c65860fe6616f30b3f79ea4b 100644 (file)
@@ -1,6 +1,8 @@
 /*
  * (C) Copyright 2017 Rockchip Electronics Co., Ltd
  * Author: Andy Yan <andy.yan@rock-chips.com>
+ * (C) Copyright 2017 Theobroma Systems Design und Consulting GmbH
+ *
  * SPDX-License-Identifier:    GPL-2.0+
  */
 
@@ -14,6 +16,10 @@ static const struct udevice_id rk3368_syscon_ids[] = {
          .data = ROCKCHIP_SYSCON_GRF },
        { .compatible = "rockchip,rk3368-pmugrf",
          .data = ROCKCHIP_SYSCON_PMUGRF },
+       { .compatible = "rockchip,rk3368-msch",
+         .data = ROCKCHIP_SYSCON_MSCH },
+       { .compatible = "rockchip,rk3368-sgrf",
+         .data = ROCKCHIP_SYSCON_SGRF },
        { }
 };
 
@@ -22,3 +28,41 @@ U_BOOT_DRIVER(syscon_rk3368) = {
        .id = UCLASS_SYSCON,
        .of_match = rk3368_syscon_ids,
 };
+
+#if CONFIG_IS_ENABLED(OF_PLATDATA)
+static int rk3368_syscon_bind_of_platdata(struct udevice *dev)
+{
+       dev->driver_data = dev->driver->of_match->data;
+       debug("syscon: %s %d\n", dev->name, (uint)dev->driver_data);
+
+       return 0;
+}
+
+U_BOOT_DRIVER(rockchip_rk3368_grf) = {
+       .name = "rockchip_rk3368_grf",
+       .id = UCLASS_SYSCON,
+       .of_match = rk3368_syscon_ids,
+       .bind = rk3368_syscon_bind_of_platdata,
+};
+
+U_BOOT_DRIVER(rockchip_rk3368_pmugrf) = {
+       .name = "rockchip_rk3368_pmugrf",
+       .id = UCLASS_SYSCON,
+       .of_match = rk3368_syscon_ids + 1,
+       .bind = rk3368_syscon_bind_of_platdata,
+};
+
+U_BOOT_DRIVER(rockchip_rk3368_msch) = {
+       .name = "rockchip_rk3368_msch",
+       .id = UCLASS_SYSCON,
+       .of_match = rk3368_syscon_ids + 2,
+       .bind = rk3368_syscon_bind_of_platdata,
+};
+
+U_BOOT_DRIVER(rockchip_rk3368_sgrf) = {
+       .name = "rockchip_rk3368_sgrf",
+       .id = UCLASS_SYSCON,
+       .of_match = rk3368_syscon_ids + 3,
+       .bind = rk3368_syscon_bind_of_platdata,
+};
+#endif