Revision | fc97ff2695d6d7fbea7d5fda7b080f405d6ee744 (tree) |
---|---|
Zeit | 2022-07-19 23:52:15 |
Autor | Tom Rini <trini@kons...> |
Commiter | Tom Rini |
Merge https://source.denx.de/u-boot/custodians/u-boot-sunxi
To quote Andre:
One prominent feature is the restructering of the clock driver, which
allows to end up with one actual driver for all variants, although we
still only compile in support for one SoC.
Also contained are some initial SPI fixes, which should fix some
problems, and enable SPI flash support for the F1C100s SoC. Those
patches revealed more problems, I will queue fixes later on, but for
now it should at least still work.
Apart from some smaller fixes (for instance for NAND operation), there
is also preparation for the upcoming Allwinner D1 support, in form of
the USB PHY driver. There are more driver support patches to come.
The gitlab CI completed successfully, including the build test for all
160 sunxi boards. I also boot tested on a few boards, but didn't have
time for more elaborate tests this time.
@@ -679,15 +679,6 @@ config MMC_SUNXI_SLOT_EXTRA | ||
679 | 679 | slot or emmc on mmc1 - mmc3. Setting this to 1, 2 or 3 will enable |
680 | 680 | support for this. |
681 | 681 | |
682 | -config INITIAL_USB_SCAN_DELAY | |
683 | - int "delay initial usb scan by x ms to allow builtin devices to init" | |
684 | - default 0 | |
685 | - ---help--- | |
686 | - Some boards have on board usb devices which need longer than the | |
687 | - USB spec's 1 second to connect from board powerup. Set this config | |
688 | - option to a non 0 value to add an extra delay before the first usb | |
689 | - bus scan. | |
690 | - | |
691 | 682 | config USB0_VBUS_PIN |
692 | 683 | string "Vbus enable pin for usb0 (otg)" |
693 | 684 | default "" |
@@ -850,8 +841,9 @@ config VIDEO_LCD_DCLK_PHASE | ||
850 | 841 | int "LCD panel display clock phase" |
851 | 842 | depends on VIDEO_SUNXI || DM_VIDEO |
852 | 843 | default 1 |
844 | + range 0 3 | |
853 | 845 | ---help--- |
854 | - Select LCD panel display clock phase shift, range 0-3. | |
846 | + Select LCD panel display clock phase shift | |
855 | 847 | |
856 | 848 | config VIDEO_LCD_POWER |
857 | 849 | string "LCD panel power enable pin" |
@@ -13,3 +13,6 @@ CONFIG_SPL_SPI_SUNXI=y | ||
13 | 13 | CONFIG_SPL_STACK=0x8000 |
14 | 14 | CONFIG_SYS_PBSIZE=1024 |
15 | 15 | # CONFIG_SYSRESET is not set |
16 | +CONFIG_SPI_FLASH_WINBOND=y | |
17 | +CONFIG_SPI_FLASH_XTX=y | |
18 | +CONFIG_SPI=y |
@@ -10,6 +10,7 @@ CONFIG_SPL_SPI_SUNXI=y | ||
10 | 10 | CONFIG_CONSOLE_MUX=y |
11 | 11 | CONFIG_SPL_STACK=0x8000 |
12 | 12 | CONFIG_SYS_PBSIZE=1024 |
13 | +CONFIG_SPI_FLASH_MACRONIX=y | |
13 | 14 | CONFIG_SPI_FLASH_WINBOND=y |
14 | 15 | CONFIG_SUN8I_EMAC=y |
15 | 16 | CONFIG_SPI=y |
@@ -64,30 +64,9 @@ static struct ccu_reset a10_resets[] = { | ||
64 | 64 | [RST_USB_PHY2] = RESET(0x0cc, BIT(2)), |
65 | 65 | }; |
66 | 66 | |
67 | -static const struct ccu_desc a10_ccu_desc = { | |
67 | +const struct ccu_desc a10_ccu_desc = { | |
68 | 68 | .gates = a10_gates, |
69 | 69 | .resets = a10_resets, |
70 | -}; | |
71 | - | |
72 | -static int a10_clk_bind(struct udevice *dev) | |
73 | -{ | |
74 | - return sunxi_reset_bind(dev, ARRAY_SIZE(a10_resets)); | |
75 | -} | |
76 | - | |
77 | -static const struct udevice_id a10_ccu_ids[] = { | |
78 | - { .compatible = "allwinner,sun4i-a10-ccu", | |
79 | - .data = (ulong)&a10_ccu_desc }, | |
80 | - { .compatible = "allwinner,sun7i-a20-ccu", | |
81 | - .data = (ulong)&a10_ccu_desc }, | |
82 | - { } | |
83 | -}; | |
84 | - | |
85 | -U_BOOT_DRIVER(clk_sun4i_a10) = { | |
86 | - .name = "sun4i_a10_ccu", | |
87 | - .id = UCLASS_CLK, | |
88 | - .of_match = a10_ccu_ids, | |
89 | - .priv_auto = sizeof(struct ccu_priv), | |
90 | - .ops = &sunxi_clk_ops, | |
91 | - .probe = sunxi_clk_probe, | |
92 | - .bind = a10_clk_bind, | |
70 | + .num_gates = ARRAY_SIZE(a10_gates), | |
71 | + .num_resets = ARRAY_SIZE(a10_resets), | |
93 | 72 | }; |
@@ -49,30 +49,9 @@ static struct ccu_reset a10s_resets[] = { | ||
49 | 49 | [RST_USB_PHY1] = RESET(0x0cc, BIT(1)), |
50 | 50 | }; |
51 | 51 | |
52 | -static const struct ccu_desc a10s_ccu_desc = { | |
52 | +const struct ccu_desc a10s_ccu_desc = { | |
53 | 53 | .gates = a10s_gates, |
54 | 54 | .resets = a10s_resets, |
55 | -}; | |
56 | - | |
57 | -static int a10s_clk_bind(struct udevice *dev) | |
58 | -{ | |
59 | - return sunxi_reset_bind(dev, ARRAY_SIZE(a10s_resets)); | |
60 | -} | |
61 | - | |
62 | -static const struct udevice_id a10s_ccu_ids[] = { | |
63 | - { .compatible = "allwinner,sun5i-a10s-ccu", | |
64 | - .data = (ulong)&a10s_ccu_desc }, | |
65 | - { .compatible = "allwinner,sun5i-a13-ccu", | |
66 | - .data = (ulong)&a10s_ccu_desc }, | |
67 | - { } | |
68 | -}; | |
69 | - | |
70 | -U_BOOT_DRIVER(clk_sun5i_a10s) = { | |
71 | - .name = "sun5i_a10s_ccu", | |
72 | - .id = UCLASS_CLK, | |
73 | - .of_match = a10s_ccu_ids, | |
74 | - .priv_auto = sizeof(struct ccu_priv), | |
75 | - .ops = &sunxi_clk_ops, | |
76 | - .probe = sunxi_clk_probe, | |
77 | - .bind = a10s_clk_bind, | |
55 | + .num_gates = ARRAY_SIZE(a10s_gates), | |
56 | + .num_resets = ARRAY_SIZE(a10s_resets), | |
78 | 57 | }; |
@@ -68,30 +68,9 @@ static struct ccu_reset a23_resets[] = { | ||
68 | 68 | [RST_BUS_UART4] = RESET(0x2d8, BIT(20)), |
69 | 69 | }; |
70 | 70 | |
71 | -static const struct ccu_desc a23_ccu_desc = { | |
71 | +const struct ccu_desc a23_ccu_desc = { | |
72 | 72 | .gates = a23_gates, |
73 | 73 | .resets = a23_resets, |
74 | -}; | |
75 | - | |
76 | -static int a23_clk_bind(struct udevice *dev) | |
77 | -{ | |
78 | - return sunxi_reset_bind(dev, ARRAY_SIZE(a23_resets)); | |
79 | -} | |
80 | - | |
81 | -static const struct udevice_id a23_clk_ids[] = { | |
82 | - { .compatible = "allwinner,sun8i-a23-ccu", | |
83 | - .data = (ulong)&a23_ccu_desc }, | |
84 | - { .compatible = "allwinner,sun8i-a33-ccu", | |
85 | - .data = (ulong)&a23_ccu_desc }, | |
86 | - { } | |
87 | -}; | |
88 | - | |
89 | -U_BOOT_DRIVER(clk_sun8i_a23) = { | |
90 | - .name = "sun8i_a23_ccu", | |
91 | - .id = UCLASS_CLK, | |
92 | - .of_match = a23_clk_ids, | |
93 | - .priv_auto = sizeof(struct ccu_priv), | |
94 | - .ops = &sunxi_clk_ops, | |
95 | - .probe = sunxi_clk_probe, | |
96 | - .bind = a23_clk_bind, | |
74 | + .num_gates = ARRAY_SIZE(a23_gates), | |
75 | + .num_resets = ARRAY_SIZE(a23_resets), | |
97 | 76 | }; |
@@ -89,28 +89,9 @@ static struct ccu_reset a31_resets[] = { | ||
89 | 89 | [RST_APB2_UART5] = RESET(0x2d8, BIT(21)), |
90 | 90 | }; |
91 | 91 | |
92 | -static const struct ccu_desc a31_ccu_desc = { | |
92 | +const struct ccu_desc a31_ccu_desc = { | |
93 | 93 | .gates = a31_gates, |
94 | 94 | .resets = a31_resets, |
95 | -}; | |
96 | - | |
97 | -static int a31_clk_bind(struct udevice *dev) | |
98 | -{ | |
99 | - return sunxi_reset_bind(dev, ARRAY_SIZE(a31_resets)); | |
100 | -} | |
101 | - | |
102 | -static const struct udevice_id a31_clk_ids[] = { | |
103 | - { .compatible = "allwinner,sun6i-a31-ccu", | |
104 | - .data = (ulong)&a31_ccu_desc }, | |
105 | - { } | |
106 | -}; | |
107 | - | |
108 | -U_BOOT_DRIVER(clk_sun6i_a31) = { | |
109 | - .name = "sun6i_a31_ccu", | |
110 | - .id = UCLASS_CLK, | |
111 | - .of_match = a31_clk_ids, | |
112 | - .priv_auto = sizeof(struct ccu_priv), | |
113 | - .ops = &sunxi_clk_ops, | |
114 | - .probe = sunxi_clk_probe, | |
115 | - .bind = a31_clk_bind, | |
95 | + .num_gates = ARRAY_SIZE(a31_gates), | |
96 | + .num_resets = ARRAY_SIZE(a31_resets), | |
116 | 97 | }; |
@@ -28,32 +28,9 @@ static struct ccu_reset a31_r_resets[] = { | ||
28 | 28 | [RST_APB0_I2C] = RESET(0x0b0, BIT(6)), |
29 | 29 | }; |
30 | 30 | |
31 | -static const struct ccu_desc a31_r_ccu_desc = { | |
31 | +const struct ccu_desc a31_r_ccu_desc = { | |
32 | 32 | .gates = a31_r_gates, |
33 | 33 | .resets = a31_r_resets, |
34 | -}; | |
35 | - | |
36 | -static int a31_r_clk_bind(struct udevice *dev) | |
37 | -{ | |
38 | - return sunxi_reset_bind(dev, ARRAY_SIZE(a31_r_resets)); | |
39 | -} | |
40 | - | |
41 | -static const struct udevice_id a31_r_clk_ids[] = { | |
42 | - { .compatible = "allwinner,sun8i-a83t-r-ccu", | |
43 | - .data = (ulong)&a31_r_ccu_desc }, | |
44 | - { .compatible = "allwinner,sun8i-h3-r-ccu", | |
45 | - .data = (ulong)&a31_r_ccu_desc }, | |
46 | - { .compatible = "allwinner,sun50i-a64-r-ccu", | |
47 | - .data = (ulong)&a31_r_ccu_desc }, | |
48 | - { } | |
49 | -}; | |
50 | - | |
51 | -U_BOOT_DRIVER(clk_sun6i_a31_r) = { | |
52 | - .name = "sun6i_a31_r_ccu", | |
53 | - .id = UCLASS_CLK, | |
54 | - .of_match = a31_r_clk_ids, | |
55 | - .priv_auto = sizeof(struct ccu_priv), | |
56 | - .ops = &sunxi_clk_ops, | |
57 | - .probe = sunxi_clk_probe, | |
58 | - .bind = a31_r_clk_bind, | |
34 | + .num_gates = ARRAY_SIZE(a31_r_gates), | |
35 | + .num_resets = ARRAY_SIZE(a31_r_resets), | |
59 | 36 | }; |
@@ -77,28 +77,9 @@ static const struct ccu_reset a64_resets[] = { | ||
77 | 77 | [RST_BUS_UART4] = RESET(0x2d8, BIT(20)), |
78 | 78 | }; |
79 | 79 | |
80 | -static const struct ccu_desc a64_ccu_desc = { | |
80 | +const struct ccu_desc a64_ccu_desc = { | |
81 | 81 | .gates = a64_gates, |
82 | 82 | .resets = a64_resets, |
83 | -}; | |
84 | - | |
85 | -static int a64_clk_bind(struct udevice *dev) | |
86 | -{ | |
87 | - return sunxi_reset_bind(dev, ARRAY_SIZE(a64_resets)); | |
88 | -} | |
89 | - | |
90 | -static const struct udevice_id a64_ccu_ids[] = { | |
91 | - { .compatible = "allwinner,sun50i-a64-ccu", | |
92 | - .data = (ulong)&a64_ccu_desc }, | |
93 | - { } | |
94 | -}; | |
95 | - | |
96 | -U_BOOT_DRIVER(clk_sun50i_a64) = { | |
97 | - .name = "sun50i_a64_ccu", | |
98 | - .id = UCLASS_CLK, | |
99 | - .of_match = a64_ccu_ids, | |
100 | - .priv_auto = sizeof(struct ccu_priv), | |
101 | - .ops = &sunxi_clk_ops, | |
102 | - .probe = sunxi_clk_probe, | |
103 | - .bind = a64_clk_bind, | |
83 | + .num_gates = ARRAY_SIZE(a64_gates), | |
84 | + .num_resets = ARRAY_SIZE(a64_resets), | |
104 | 85 | }; |
@@ -74,40 +74,16 @@ static const struct ccu_reset a80_mmc_resets[] = { | ||
74 | 74 | [3] = GATE(0xc, BIT(18)), |
75 | 75 | }; |
76 | 76 | |
77 | -static const struct ccu_desc a80_ccu_desc = { | |
77 | +const struct ccu_desc a80_ccu_desc = { | |
78 | 78 | .gates = a80_gates, |
79 | 79 | .resets = a80_resets, |
80 | + .num_gates = ARRAY_SIZE(a80_gates), | |
81 | + .num_resets = ARRAY_SIZE(a80_resets), | |
80 | 82 | }; |
81 | 83 | |
82 | -static const struct ccu_desc a80_mmc_clk_desc = { | |
84 | +const struct ccu_desc a80_mmc_clk_desc = { | |
83 | 85 | .gates = a80_mmc_gates, |
84 | 86 | .resets = a80_mmc_resets, |
85 | -}; | |
86 | - | |
87 | -static int a80_clk_bind(struct udevice *dev) | |
88 | -{ | |
89 | - ulong count = ARRAY_SIZE(a80_resets); | |
90 | - | |
91 | - if (device_is_compatible(dev, "allwinner,sun9i-a80-mmc-config-clk")) | |
92 | - count = ARRAY_SIZE(a80_mmc_resets); | |
93 | - | |
94 | - return sunxi_reset_bind(dev, count); | |
95 | -} | |
96 | - | |
97 | -static const struct udevice_id a80_ccu_ids[] = { | |
98 | - { .compatible = "allwinner,sun9i-a80-ccu", | |
99 | - .data = (ulong)&a80_ccu_desc }, | |
100 | - { .compatible = "allwinner,sun9i-a80-mmc-config-clk", | |
101 | - .data = (ulong)&a80_mmc_clk_desc }, | |
102 | - { } | |
103 | -}; | |
104 | - | |
105 | -U_BOOT_DRIVER(clk_sun9i_a80) = { | |
106 | - .name = "sun9i_a80_ccu", | |
107 | - .id = UCLASS_CLK, | |
108 | - .of_match = a80_ccu_ids, | |
109 | - .priv_auto = sizeof(struct ccu_priv), | |
110 | - .ops = &sunxi_clk_ops, | |
111 | - .probe = sunxi_clk_probe, | |
112 | - .bind = a80_clk_bind, | |
87 | + .num_gates = ARRAY_SIZE(a80_mmc_gates), | |
88 | + .num_resets = ARRAY_SIZE(a80_mmc_resets), | |
113 | 89 | }; |
@@ -72,28 +72,9 @@ static struct ccu_reset a83t_resets[] = { | ||
72 | 72 | [RST_BUS_UART4] = RESET(0x2d8, BIT(20)), |
73 | 73 | }; |
74 | 74 | |
75 | -static const struct ccu_desc a83t_ccu_desc = { | |
75 | +const struct ccu_desc a83t_ccu_desc = { | |
76 | 76 | .gates = a83t_gates, |
77 | 77 | .resets = a83t_resets, |
78 | -}; | |
79 | - | |
80 | -static int a83t_clk_bind(struct udevice *dev) | |
81 | -{ | |
82 | - return sunxi_reset_bind(dev, ARRAY_SIZE(a83t_resets)); | |
83 | -} | |
84 | - | |
85 | -static const struct udevice_id a83t_clk_ids[] = { | |
86 | - { .compatible = "allwinner,sun8i-a83t-ccu", | |
87 | - .data = (ulong)&a83t_ccu_desc }, | |
88 | - { } | |
89 | -}; | |
90 | - | |
91 | -U_BOOT_DRIVER(clk_sun8i_a83t) = { | |
92 | - .name = "sun8i_a83t_ccu", | |
93 | - .id = UCLASS_CLK, | |
94 | - .of_match = a83t_clk_ids, | |
95 | - .priv_auto = sizeof(struct ccu_priv), | |
96 | - .ops = &sunxi_clk_ops, | |
97 | - .probe = sunxi_clk_probe, | |
98 | - .bind = a83t_clk_bind, | |
78 | + .num_gates = ARRAY_SIZE(a83t_gates), | |
79 | + .num_resets = ARRAY_SIZE(a83t_resets), | |
99 | 80 | }; |
@@ -47,28 +47,9 @@ static struct ccu_reset f1c100s_resets[] = { | ||
47 | 47 | [RST_BUS_UART2] = RESET(0x2d0, BIT(22)), |
48 | 48 | }; |
49 | 49 | |
50 | -static const struct ccu_desc f1c100s_ccu_desc = { | |
50 | +const struct ccu_desc f1c100s_ccu_desc = { | |
51 | 51 | .gates = f1c100s_gates, |
52 | 52 | .resets = f1c100s_resets, |
53 | -}; | |
54 | - | |
55 | -static int f1c100s_clk_bind(struct udevice *dev) | |
56 | -{ | |
57 | - return sunxi_reset_bind(dev, ARRAY_SIZE(f1c100s_resets)); | |
58 | -} | |
59 | - | |
60 | -static const struct udevice_id f1c100s_clk_ids[] = { | |
61 | - { .compatible = "allwinner,suniv-f1c100s-ccu", | |
62 | - .data = (ulong)&f1c100s_ccu_desc }, | |
63 | - { } | |
64 | -}; | |
65 | - | |
66 | -U_BOOT_DRIVER(clk_suniv_f1c100s) = { | |
67 | - .name = "suniv_f1c100s_ccu", | |
68 | - .id = UCLASS_CLK, | |
69 | - .of_match = f1c100s_clk_ids, | |
70 | - .priv_auto = sizeof(struct ccu_priv), | |
71 | - .ops = &sunxi_clk_ops, | |
72 | - .probe = sunxi_clk_probe, | |
73 | - .bind = f1c100s_clk_bind, | |
53 | + .num_gates = ARRAY_SIZE(f1c100s_gates), | |
54 | + .num_resets = ARRAY_SIZE(f1c100s_resets), | |
74 | 55 | }; |
@@ -90,30 +90,9 @@ static struct ccu_reset h3_resets[] = { | ||
90 | 90 | [RST_BUS_UART3] = RESET(0x2d8, BIT(19)), |
91 | 91 | }; |
92 | 92 | |
93 | -static const struct ccu_desc h3_ccu_desc = { | |
93 | +const struct ccu_desc h3_ccu_desc = { | |
94 | 94 | .gates = h3_gates, |
95 | 95 | .resets = h3_resets, |
96 | -}; | |
97 | - | |
98 | -static int h3_clk_bind(struct udevice *dev) | |
99 | -{ | |
100 | - return sunxi_reset_bind(dev, ARRAY_SIZE(h3_resets)); | |
101 | -} | |
102 | - | |
103 | -static const struct udevice_id h3_ccu_ids[] = { | |
104 | - { .compatible = "allwinner,sun8i-h3-ccu", | |
105 | - .data = (ulong)&h3_ccu_desc }, | |
106 | - { .compatible = "allwinner,sun50i-h5-ccu", | |
107 | - .data = (ulong)&h3_ccu_desc }, | |
108 | - { } | |
109 | -}; | |
110 | - | |
111 | -U_BOOT_DRIVER(clk_sun8i_h3) = { | |
112 | - .name = "sun8i_h3_ccu", | |
113 | - .id = UCLASS_CLK, | |
114 | - .of_match = h3_ccu_ids, | |
115 | - .priv_auto = sizeof(struct ccu_priv), | |
116 | - .ops = &sunxi_clk_ops, | |
117 | - .probe = sunxi_clk_probe, | |
118 | - .bind = h3_clk_bind, | |
96 | + .num_gates = ARRAY_SIZE(h3_gates), | |
97 | + .num_resets = ARRAY_SIZE(h3_resets), | |
119 | 98 | }; |
@@ -91,28 +91,9 @@ static struct ccu_reset h6_resets[] = { | ||
91 | 91 | [RST_BUS_OTG] = RESET(0xa8c, BIT(24)), |
92 | 92 | }; |
93 | 93 | |
94 | -static const struct ccu_desc h6_ccu_desc = { | |
94 | +const struct ccu_desc h6_ccu_desc = { | |
95 | 95 | .gates = h6_gates, |
96 | 96 | .resets = h6_resets, |
97 | -}; | |
98 | - | |
99 | -static int h6_clk_bind(struct udevice *dev) | |
100 | -{ | |
101 | - return sunxi_reset_bind(dev, ARRAY_SIZE(h6_resets)); | |
102 | -} | |
103 | - | |
104 | -static const struct udevice_id h6_ccu_ids[] = { | |
105 | - { .compatible = "allwinner,sun50i-h6-ccu", | |
106 | - .data = (ulong)&h6_ccu_desc }, | |
107 | - { } | |
108 | -}; | |
109 | - | |
110 | -U_BOOT_DRIVER(clk_sun50i_h6) = { | |
111 | - .name = "sun50i_h6_ccu", | |
112 | - .id = UCLASS_CLK, | |
113 | - .of_match = h6_ccu_ids, | |
114 | - .priv_auto = sizeof(struct ccu_priv), | |
115 | - .ops = &sunxi_clk_ops, | |
116 | - .probe = sunxi_clk_probe, | |
117 | - .bind = h6_clk_bind, | |
97 | + .num_gates = ARRAY_SIZE(h6_gates), | |
98 | + .num_resets = ARRAY_SIZE(h6_resets), | |
118 | 99 | }; |
@@ -109,28 +109,9 @@ static struct ccu_reset h616_resets[] = { | ||
109 | 109 | [RST_BUS_OTG] = RESET(0xa8c, BIT(24)), |
110 | 110 | }; |
111 | 111 | |
112 | -static const struct ccu_desc h616_ccu_desc = { | |
112 | +const struct ccu_desc h616_ccu_desc = { | |
113 | 113 | .gates = h616_gates, |
114 | 114 | .resets = h616_resets, |
115 | -}; | |
116 | - | |
117 | -static int h616_clk_bind(struct udevice *dev) | |
118 | -{ | |
119 | - return sunxi_reset_bind(dev, ARRAY_SIZE(h616_resets)); | |
120 | -} | |
121 | - | |
122 | -static const struct udevice_id h616_ccu_ids[] = { | |
123 | - { .compatible = "allwinner,sun50i-h616-ccu", | |
124 | - .data = (ulong)&h616_ccu_desc }, | |
125 | - { } | |
126 | -}; | |
127 | - | |
128 | -U_BOOT_DRIVER(clk_sun50i_h616) = { | |
129 | - .name = "sun50i_h616_ccu", | |
130 | - .id = UCLASS_CLK, | |
131 | - .of_match = h616_ccu_ids, | |
132 | - .priv_auto = sizeof(struct ccu_priv), | |
133 | - .ops = &sunxi_clk_ops, | |
134 | - .probe = sunxi_clk_probe, | |
135 | - .bind = h616_clk_bind, | |
115 | + .num_gates = ARRAY_SIZE(h616_gates), | |
116 | + .num_resets = ARRAY_SIZE(h616_resets), | |
136 | 117 | }; |
@@ -34,30 +34,9 @@ static struct ccu_reset h6_r_resets[] = { | ||
34 | 34 | [RST_R_APB1_W1] = RESET(0x1ec, BIT(16)), |
35 | 35 | }; |
36 | 36 | |
37 | -static const struct ccu_desc h6_r_ccu_desc = { | |
37 | +const struct ccu_desc h6_r_ccu_desc = { | |
38 | 38 | .gates = h6_r_gates, |
39 | 39 | .resets = h6_r_resets, |
40 | -}; | |
41 | - | |
42 | -static int h6_r_clk_bind(struct udevice *dev) | |
43 | -{ | |
44 | - return sunxi_reset_bind(dev, ARRAY_SIZE(h6_r_resets)); | |
45 | -} | |
46 | - | |
47 | -static const struct udevice_id h6_r_clk_ids[] = { | |
48 | - { .compatible = "allwinner,sun50i-h6-r-ccu", | |
49 | - .data = (ulong)&h6_r_ccu_desc }, | |
50 | - { .compatible = "allwinner,sun50i-h616-r-ccu", | |
51 | - .data = (ulong)&h6_r_ccu_desc }, | |
52 | - { } | |
53 | -}; | |
54 | - | |
55 | -U_BOOT_DRIVER(clk_sun50i_h6_r) = { | |
56 | - .name = "sun50i_h6_r_ccu", | |
57 | - .id = UCLASS_CLK, | |
58 | - .of_match = h6_r_clk_ids, | |
59 | - .priv_auto = sizeof(struct ccu_priv), | |
60 | - .ops = &sunxi_clk_ops, | |
61 | - .probe = sunxi_clk_probe, | |
62 | - .bind = h6_r_clk_bind, | |
40 | + .num_gates = ARRAY_SIZE(h6_r_gates), | |
41 | + .num_resets = ARRAY_SIZE(h6_r_resets), | |
63 | 42 | }; |
@@ -99,28 +99,9 @@ static struct ccu_reset r40_resets[] = { | ||
99 | 99 | [RST_BUS_UART7] = RESET(0x2d8, BIT(23)), |
100 | 100 | }; |
101 | 101 | |
102 | -static const struct ccu_desc r40_ccu_desc = { | |
102 | +const struct ccu_desc r40_ccu_desc = { | |
103 | 103 | .gates = r40_gates, |
104 | 104 | .resets = r40_resets, |
105 | -}; | |
106 | - | |
107 | -static int r40_clk_bind(struct udevice *dev) | |
108 | -{ | |
109 | - return sunxi_reset_bind(dev, ARRAY_SIZE(r40_resets)); | |
110 | -} | |
111 | - | |
112 | -static const struct udevice_id r40_clk_ids[] = { | |
113 | - { .compatible = "allwinner,sun8i-r40-ccu", | |
114 | - .data = (ulong)&r40_ccu_desc }, | |
115 | - { } | |
116 | -}; | |
117 | - | |
118 | -U_BOOT_DRIVER(clk_sun8i_r40) = { | |
119 | - .name = "sun8i_r40_ccu", | |
120 | - .id = UCLASS_CLK, | |
121 | - .of_match = r40_clk_ids, | |
122 | - .priv_auto = sizeof(struct ccu_priv), | |
123 | - .ops = &sunxi_clk_ops, | |
124 | - .probe = sunxi_clk_probe, | |
125 | - .bind = r40_clk_bind, | |
105 | + .num_gates = ARRAY_SIZE(r40_gates), | |
106 | + .num_resets = ARRAY_SIZE(r40_resets), | |
126 | 107 | }; |
@@ -12,25 +12,31 @@ | ||
12 | 12 | #include <reset.h> |
13 | 13 | #include <asm/io.h> |
14 | 14 | #include <clk/sunxi.h> |
15 | +#include <dm/device-internal.h> | |
15 | 16 | #include <linux/bitops.h> |
16 | 17 | #include <linux/log2.h> |
17 | 18 | |
18 | -static const struct ccu_clk_gate *priv_to_gate(struct ccu_priv *priv, | |
19 | +extern U_BOOT_DRIVER(sunxi_reset); | |
20 | + | |
21 | +static const struct ccu_clk_gate *plat_to_gate(struct ccu_plat *plat, | |
19 | 22 | unsigned long id) |
20 | 23 | { |
21 | - return &priv->desc->gates[id]; | |
24 | + if (id >= plat->desc->num_gates) | |
25 | + return NULL; | |
26 | + | |
27 | + return &plat->desc->gates[id]; | |
22 | 28 | } |
23 | 29 | |
24 | 30 | static int sunxi_set_gate(struct clk *clk, bool on) |
25 | 31 | { |
26 | - struct ccu_priv *priv = dev_get_priv(clk->dev); | |
27 | - const struct ccu_clk_gate *gate = priv_to_gate(priv, clk->id); | |
32 | + struct ccu_plat *plat = dev_get_plat(clk->dev); | |
33 | + const struct ccu_clk_gate *gate = plat_to_gate(plat, clk->id); | |
28 | 34 | u32 reg; |
29 | 35 | |
30 | - if ((gate->flags & CCU_CLK_F_DUMMY_GATE)) | |
36 | + if (gate && (gate->flags & CCU_CLK_F_DUMMY_GATE)) | |
31 | 37 | return 0; |
32 | 38 | |
33 | - if (!(gate->flags & CCU_CLK_F_IS_VALID)) { | |
39 | + if (!gate || !(gate->flags & CCU_CLK_F_IS_VALID)) { | |
34 | 40 | printf("%s: (CLK#%ld) unhandled\n", __func__, clk->id); |
35 | 41 | return 0; |
36 | 42 | } |
@@ -38,13 +44,13 @@ static int sunxi_set_gate(struct clk *clk, bool on) | ||
38 | 44 | debug("%s: (CLK#%ld) off#0x%x, BIT(%d)\n", __func__, |
39 | 45 | clk->id, gate->off, ilog2(gate->bit)); |
40 | 46 | |
41 | - reg = readl(priv->base + gate->off); | |
47 | + reg = readl(plat->base + gate->off); | |
42 | 48 | if (on) |
43 | 49 | reg |= gate->bit; |
44 | 50 | else |
45 | 51 | reg &= ~gate->bit; |
46 | 52 | |
47 | - writel(reg, priv->base + gate->off); | |
53 | + writel(reg, plat->base + gate->off); | |
48 | 54 | |
49 | 55 | return 0; |
50 | 56 | } |
@@ -64,21 +70,19 @@ struct clk_ops sunxi_clk_ops = { | ||
64 | 70 | .disable = sunxi_clk_disable, |
65 | 71 | }; |
66 | 72 | |
67 | -int sunxi_clk_probe(struct udevice *dev) | |
73 | +static int sunxi_clk_bind(struct udevice *dev) | |
74 | +{ | |
75 | + /* Reuse the platform data for the reset driver. */ | |
76 | + return device_bind(dev, DM_DRIVER_REF(sunxi_reset), "reset", | |
77 | + dev_get_plat(dev), dev_ofnode(dev), NULL); | |
78 | +} | |
79 | + | |
80 | +static int sunxi_clk_probe(struct udevice *dev) | |
68 | 81 | { |
69 | - struct ccu_priv *priv = dev_get_priv(dev); | |
70 | 82 | struct clk_bulk clk_bulk; |
71 | 83 | struct reset_ctl_bulk rst_bulk; |
72 | 84 | int ret; |
73 | 85 | |
74 | - priv->base = dev_read_addr_ptr(dev); | |
75 | - if (!priv->base) | |
76 | - return -ENOMEM; | |
77 | - | |
78 | - priv->desc = (const struct ccu_desc *)dev_get_driver_data(dev); | |
79 | - if (!priv->desc) | |
80 | - return -EINVAL; | |
81 | - | |
82 | 86 | ret = clk_get_bulk(dev, &clk_bulk); |
83 | 87 | if (!ret) |
84 | 88 | clk_enable_bulk(&clk_bulk); |
@@ -89,3 +93,138 @@ int sunxi_clk_probe(struct udevice *dev) | ||
89 | 93 | |
90 | 94 | return 0; |
91 | 95 | } |
96 | + | |
97 | +static int sunxi_clk_of_to_plat(struct udevice *dev) | |
98 | +{ | |
99 | + struct ccu_plat *plat = dev_get_plat(dev); | |
100 | + | |
101 | + plat->base = dev_read_addr_ptr(dev); | |
102 | + if (!plat->base) | |
103 | + return -ENOMEM; | |
104 | + | |
105 | + plat->desc = (const struct ccu_desc *)dev_get_driver_data(dev); | |
106 | + if (!plat->desc) | |
107 | + return -EINVAL; | |
108 | + | |
109 | + return 0; | |
110 | +} | |
111 | + | |
112 | +extern const struct ccu_desc a10_ccu_desc; | |
113 | +extern const struct ccu_desc a10s_ccu_desc; | |
114 | +extern const struct ccu_desc a23_ccu_desc; | |
115 | +extern const struct ccu_desc a31_ccu_desc; | |
116 | +extern const struct ccu_desc a31_r_ccu_desc; | |
117 | +extern const struct ccu_desc a64_ccu_desc; | |
118 | +extern const struct ccu_desc a80_ccu_desc; | |
119 | +extern const struct ccu_desc a80_mmc_clk_desc; | |
120 | +extern const struct ccu_desc a83t_ccu_desc; | |
121 | +extern const struct ccu_desc f1c100s_ccu_desc; | |
122 | +extern const struct ccu_desc h3_ccu_desc; | |
123 | +extern const struct ccu_desc h6_ccu_desc; | |
124 | +extern const struct ccu_desc h616_ccu_desc; | |
125 | +extern const struct ccu_desc h6_r_ccu_desc; | |
126 | +extern const struct ccu_desc r40_ccu_desc; | |
127 | +extern const struct ccu_desc v3s_ccu_desc; | |
128 | + | |
129 | +static const struct udevice_id sunxi_clk_ids[] = { | |
130 | +#ifdef CONFIG_CLK_SUN4I_A10 | |
131 | + { .compatible = "allwinner,sun4i-a10-ccu", | |
132 | + .data = (ulong)&a10_ccu_desc }, | |
133 | +#endif | |
134 | +#ifdef CONFIG_CLK_SUN5I_A10S | |
135 | + { .compatible = "allwinner,sun5i-a10s-ccu", | |
136 | + .data = (ulong)&a10s_ccu_desc }, | |
137 | + { .compatible = "allwinner,sun5i-a13-ccu", | |
138 | + .data = (ulong)&a10s_ccu_desc }, | |
139 | +#endif | |
140 | +#ifdef CONFIG_CLK_SUN6I_A31 | |
141 | + { .compatible = "allwinner,sun6i-a31-ccu", | |
142 | + .data = (ulong)&a31_ccu_desc }, | |
143 | +#endif | |
144 | +#ifdef CONFIG_CLK_SUN4I_A10 | |
145 | + { .compatible = "allwinner,sun7i-a20-ccu", | |
146 | + .data = (ulong)&a10_ccu_desc }, | |
147 | +#endif | |
148 | +#ifdef CONFIG_CLK_SUN8I_A23 | |
149 | + { .compatible = "allwinner,sun8i-a23-ccu", | |
150 | + .data = (ulong)&a23_ccu_desc }, | |
151 | + { .compatible = "allwinner,sun8i-a33-ccu", | |
152 | + .data = (ulong)&a23_ccu_desc }, | |
153 | +#endif | |
154 | +#ifdef CONFIG_CLK_SUN8I_A83T | |
155 | + { .compatible = "allwinner,sun8i-a83t-ccu", | |
156 | + .data = (ulong)&a83t_ccu_desc }, | |
157 | +#endif | |
158 | +#ifdef CONFIG_CLK_SUN6I_A31_R | |
159 | + { .compatible = "allwinner,sun8i-a83t-r-ccu", | |
160 | + .data = (ulong)&a31_r_ccu_desc }, | |
161 | +#endif | |
162 | +#ifdef CONFIG_CLK_SUN8I_H3 | |
163 | + { .compatible = "allwinner,sun8i-h3-ccu", | |
164 | + .data = (ulong)&h3_ccu_desc }, | |
165 | +#endif | |
166 | +#ifdef CONFIG_CLK_SUN6I_A31_R | |
167 | + { .compatible = "allwinner,sun8i-h3-r-ccu", | |
168 | + .data = (ulong)&a31_r_ccu_desc }, | |
169 | +#endif | |
170 | +#ifdef CONFIG_CLK_SUN8I_R40 | |
171 | + { .compatible = "allwinner,sun8i-r40-ccu", | |
172 | + .data = (ulong)&r40_ccu_desc }, | |
173 | +#endif | |
174 | +#ifdef CONFIG_CLK_SUN8I_V3S | |
175 | + { .compatible = "allwinner,sun8i-v3-ccu", | |
176 | + .data = (ulong)&v3s_ccu_desc }, | |
177 | + { .compatible = "allwinner,sun8i-v3s-ccu", | |
178 | + .data = (ulong)&v3s_ccu_desc }, | |
179 | +#endif | |
180 | +#ifdef CONFIG_CLK_SUN9I_A80 | |
181 | + { .compatible = "allwinner,sun9i-a80-ccu", | |
182 | + .data = (ulong)&a80_ccu_desc }, | |
183 | + { .compatible = "allwinner,sun9i-a80-mmc-config-clk", | |
184 | + .data = (ulong)&a80_mmc_clk_desc }, | |
185 | +#endif | |
186 | +#ifdef CONFIG_CLK_SUN50I_A64 | |
187 | + { .compatible = "allwinner,sun50i-a64-ccu", | |
188 | + .data = (ulong)&a64_ccu_desc }, | |
189 | +#endif | |
190 | +#ifdef CONFIG_CLK_SUN6I_A31_R | |
191 | + { .compatible = "allwinner,sun50i-a64-r-ccu", | |
192 | + .data = (ulong)&a31_r_ccu_desc }, | |
193 | +#endif | |
194 | +#ifdef CONFIG_CLK_SUN8I_H3 | |
195 | + { .compatible = "allwinner,sun50i-h5-ccu", | |
196 | + .data = (ulong)&h3_ccu_desc }, | |
197 | +#endif | |
198 | +#ifdef CONFIG_CLK_SUN50I_H6 | |
199 | + { .compatible = "allwinner,sun50i-h6-ccu", | |
200 | + .data = (ulong)&h6_ccu_desc }, | |
201 | +#endif | |
202 | +#ifdef CONFIG_CLK_SUN50I_H6_R | |
203 | + { .compatible = "allwinner,sun50i-h6-r-ccu", | |
204 | + .data = (ulong)&h6_r_ccu_desc }, | |
205 | +#endif | |
206 | +#ifdef CONFIG_CLK_SUN50I_H616 | |
207 | + { .compatible = "allwinner,sun50i-h616-ccu", | |
208 | + .data = (ulong)&h616_ccu_desc }, | |
209 | +#endif | |
210 | +#ifdef CONFIG_CLK_SUN50I_H6_R | |
211 | + { .compatible = "allwinner,sun50i-h616-r-ccu", | |
212 | + .data = (ulong)&h6_r_ccu_desc }, | |
213 | +#endif | |
214 | +#ifdef CONFIG_CLK_SUNIV_F1C100S | |
215 | + { .compatible = "allwinner,suniv-f1c100s-ccu", | |
216 | + .data = (ulong)&f1c100s_ccu_desc }, | |
217 | +#endif | |
218 | + { } | |
219 | +}; | |
220 | + | |
221 | +U_BOOT_DRIVER(sunxi_clk) = { | |
222 | + .name = "sunxi_clk", | |
223 | + .id = UCLASS_CLK, | |
224 | + .of_match = sunxi_clk_ids, | |
225 | + .bind = sunxi_clk_bind, | |
226 | + .probe = sunxi_clk_probe, | |
227 | + .of_to_plat = sunxi_clk_of_to_plat, | |
228 | + .plat_auto = sizeof(struct ccu_plat), | |
229 | + .ops = &sunxi_clk_ops, | |
230 | +}; |
@@ -49,30 +49,9 @@ static struct ccu_reset v3s_resets[] = { | ||
49 | 49 | [RST_BUS_UART2] = RESET(0x2d8, BIT(18)), |
50 | 50 | }; |
51 | 51 | |
52 | -static const struct ccu_desc v3s_ccu_desc = { | |
52 | +const struct ccu_desc v3s_ccu_desc = { | |
53 | 53 | .gates = v3s_gates, |
54 | 54 | .resets = v3s_resets, |
55 | -}; | |
56 | - | |
57 | -static int v3s_clk_bind(struct udevice *dev) | |
58 | -{ | |
59 | - return sunxi_reset_bind(dev, ARRAY_SIZE(v3s_resets)); | |
60 | -} | |
61 | - | |
62 | -static const struct udevice_id v3s_clk_ids[] = { | |
63 | - { .compatible = "allwinner,sun8i-v3s-ccu", | |
64 | - .data = (ulong)&v3s_ccu_desc }, | |
65 | - { .compatible = "allwinner,sun8i-v3-ccu", | |
66 | - .data = (ulong)&v3s_ccu_desc }, | |
67 | - { } | |
68 | -}; | |
69 | - | |
70 | -U_BOOT_DRIVER(clk_sun8i_v3s) = { | |
71 | - .name = "sun8i_v3s_ccu", | |
72 | - .id = UCLASS_CLK, | |
73 | - .of_match = v3s_clk_ids, | |
74 | - .priv_auto = sizeof(struct ccu_priv), | |
75 | - .ops = &sunxi_clk_ops, | |
76 | - .probe = sunxi_clk_probe, | |
77 | - .bind = v3s_clk_bind, | |
55 | + .num_gates = ARRAY_SIZE(v3s_gates), | |
56 | + .num_resets = ARRAY_SIZE(v3s_resets), | |
78 | 57 | }; |
@@ -208,7 +208,7 @@ static void nand_apply_config(const struct nfc_config *conf) | ||
208 | 208 | |
209 | 209 | val = readl(SUNXI_NFC_BASE + NFC_CTL); |
210 | 210 | val &= ~NFC_CTL_PAGE_SIZE_MASK; |
211 | - writel(val | NFC_CTL_RAM_METHOD | NFC_CTL_PAGE_SIZE(conf->page_size), | |
211 | + writel(val | NFC_CTL_PAGE_SIZE(conf->page_size), | |
212 | 212 | SUNXI_NFC_BASE + NFC_CTL); |
213 | 213 | writel(conf->ecc_size, SUNXI_NFC_BASE + NFC_CNT); |
214 | 214 | writel(conf->page_size, SUNXI_NFC_BASE + NFC_SPARE_AREA); |
@@ -16,7 +16,6 @@ | ||
16 | 16 | #include <asm/global_data.h> |
17 | 17 | #include <asm/gpio.h> |
18 | 18 | #include <asm/io.h> |
19 | -#include <asm/arch/clock.h> | |
20 | 19 | #include <common.h> |
21 | 20 | #include <clk.h> |
22 | 21 | #include <dm.h> |
@@ -857,7 +856,7 @@ static int sun8i_emac_eth_of_to_plat(struct udevice *dev) | ||
857 | 856 | priv->phyaddr = fdtdec_get_int(gd->fdt_blob, offset, "reg", -1); |
858 | 857 | |
859 | 858 | pdata->phy_interface = dev_read_phy_mode(dev); |
860 | - printf("phy interface%d\n", pdata->phy_interface); | |
859 | + debug("phy interface %d\n", pdata->phy_interface); | |
861 | 860 | if (pdata->phy_interface == PHY_INTERFACE_MODE_NA) |
862 | 861 | return -EINVAL; |
863 | 862 |
@@ -13,6 +13,16 @@ config PHY_SUN4I_USB | ||
13 | 13 | This driver controls the entire USB PHY block, both the USB OTG |
14 | 14 | parts, as well as the 2 regular USB 2 host PHYs. |
15 | 15 | |
16 | +config INITIAL_USB_SCAN_DELAY | |
17 | + int "Delay initial USB scan by x ms to allow builtin devices to init" | |
18 | + depends on PHY_SUN4I_USB | |
19 | + default 0 | |
20 | + help | |
21 | + Some boards have on board usb devices which need longer than | |
22 | + the USB spec's 1 second to connect from board powerup. Set | |
23 | + this option to a nonzero value to add an extra delay before | |
24 | + the first USB bus scan. | |
25 | + | |
16 | 26 | config PHY_SUN50I_USB3 |
17 | 27 | bool "Allwinner sun50i USB3 PHY driver" |
18 | 28 | depends on ARCH_SUNXI |
@@ -20,8 +20,6 @@ | ||
20 | 20 | #include <reset.h> |
21 | 21 | #include <asm/gpio.h> |
22 | 22 | #include <asm/io.h> |
23 | -#include <asm/arch/clock.h> | |
24 | -#include <asm/arch/cpu.h> | |
25 | 23 | #include <dm/device_compat.h> |
26 | 24 | #include <linux/bitops.h> |
27 | 25 | #include <linux/delay.h> |
@@ -34,7 +32,8 @@ | ||
34 | 32 | #define REG_PHYTUNE 0x0c |
35 | 33 | #define REG_PHYCTL_A33 0x10 |
36 | 34 | #define REG_PHY_OTGCTL 0x20 |
37 | -#define REG_PMU_UNK1 0x10 | |
35 | + | |
36 | +#define REG_HCI_PHY_CTL 0x10 | |
38 | 37 | |
39 | 38 | /* Common Control Bits for Both PHYs */ |
40 | 39 | #define PHY_PLL_BW 0x03 |
@@ -65,6 +64,7 @@ | ||
65 | 64 | /* A83T specific control bits for PHY0 */ |
66 | 65 | #define PHY_CTL_VBUSVLDEXT BIT(5) |
67 | 66 | #define PHY_CTL_SIDDQ BIT(3) |
67 | +#define PHY_CTL_H3_SIDDQ BIT(1) | |
68 | 68 | |
69 | 69 | /* A83T specific control bits for PHY2 HSIC */ |
70 | 70 | #define SUNXI_EHCI_HS_FORCE BIT(20) |
@@ -89,9 +89,9 @@ struct sun4i_usb_phy_cfg { | ||
89 | 89 | int num_phys; |
90 | 90 | enum sun4i_usb_phy_type type; |
91 | 91 | u32 disc_thresh; |
92 | + u32 hci_phy_ctl_clear; | |
92 | 93 | u8 phyctl_offset; |
93 | 94 | bool dedicated_clocks; |
94 | - bool enable_pmu_unk1; | |
95 | 95 | bool phy0_dual_route; |
96 | 96 | int missing_phys; |
97 | 97 | }; |
@@ -277,6 +277,12 @@ static int sun4i_usb_phy_init(struct phy *phy) | ||
277 | 277 | return ret; |
278 | 278 | } |
279 | 279 | |
280 | + if (usb_phy->pmu && data->cfg->hci_phy_ctl_clear) { | |
281 | + val = readl(usb_phy->pmu + REG_HCI_PHY_CTL); | |
282 | + val &= ~data->cfg->hci_phy_ctl_clear; | |
283 | + writel(val, usb_phy->pmu + REG_HCI_PHY_CTL); | |
284 | + } | |
285 | + | |
280 | 286 | if (data->cfg->type == sun8i_a83t_phy || |
281 | 287 | data->cfg->type == sun50i_h6_phy) { |
282 | 288 | if (phy->id == 0) { |
@@ -286,11 +292,6 @@ static int sun4i_usb_phy_init(struct phy *phy) | ||
286 | 292 | writel(val, data->base + data->cfg->phyctl_offset); |
287 | 293 | } |
288 | 294 | } else { |
289 | - if (usb_phy->pmu && data->cfg->enable_pmu_unk1) { | |
290 | - val = readl(usb_phy->pmu + REG_PMU_UNK1); | |
291 | - writel(val & ~2, usb_phy->pmu + REG_PMU_UNK1); | |
292 | - } | |
293 | - | |
294 | 295 | if (usb_phy->id == 0) |
295 | 296 | sun4i_usb_phy_write(phy, PHY_RES45_CAL_EN, |
296 | 297 | PHY_RES45_CAL_DATA, |
@@ -530,7 +531,6 @@ static const struct sun4i_usb_phy_cfg sun4i_a10_cfg = { | ||
530 | 531 | .disc_thresh = 3, |
531 | 532 | .phyctl_offset = REG_PHYCTL_A10, |
532 | 533 | .dedicated_clocks = false, |
533 | - .enable_pmu_unk1 = false, | |
534 | 534 | }; |
535 | 535 | |
536 | 536 | static const struct sun4i_usb_phy_cfg sun5i_a13_cfg = { |
@@ -539,7 +539,6 @@ static const struct sun4i_usb_phy_cfg sun5i_a13_cfg = { | ||
539 | 539 | .disc_thresh = 2, |
540 | 540 | .phyctl_offset = REG_PHYCTL_A10, |
541 | 541 | .dedicated_clocks = false, |
542 | - .enable_pmu_unk1 = false, | |
543 | 542 | }; |
544 | 543 | |
545 | 544 | static const struct sun4i_usb_phy_cfg sun6i_a31_cfg = { |
@@ -548,7 +547,6 @@ static const struct sun4i_usb_phy_cfg sun6i_a31_cfg = { | ||
548 | 547 | .disc_thresh = 3, |
549 | 548 | .phyctl_offset = REG_PHYCTL_A10, |
550 | 549 | .dedicated_clocks = true, |
551 | - .enable_pmu_unk1 = false, | |
552 | 550 | }; |
553 | 551 | |
554 | 552 | static const struct sun4i_usb_phy_cfg sun7i_a20_cfg = { |
@@ -557,7 +555,6 @@ static const struct sun4i_usb_phy_cfg sun7i_a20_cfg = { | ||
557 | 555 | .disc_thresh = 2, |
558 | 556 | .phyctl_offset = REG_PHYCTL_A10, |
559 | 557 | .dedicated_clocks = false, |
560 | - .enable_pmu_unk1 = false, | |
561 | 558 | }; |
562 | 559 | |
563 | 560 | static const struct sun4i_usb_phy_cfg sun8i_a23_cfg = { |
@@ -566,7 +563,6 @@ static const struct sun4i_usb_phy_cfg sun8i_a23_cfg = { | ||
566 | 563 | .disc_thresh = 3, |
567 | 564 | .phyctl_offset = REG_PHYCTL_A10, |
568 | 565 | .dedicated_clocks = true, |
569 | - .enable_pmu_unk1 = false, | |
570 | 566 | }; |
571 | 567 | |
572 | 568 | static const struct sun4i_usb_phy_cfg sun8i_a33_cfg = { |
@@ -575,7 +571,6 @@ static const struct sun4i_usb_phy_cfg sun8i_a33_cfg = { | ||
575 | 571 | .disc_thresh = 3, |
576 | 572 | .phyctl_offset = REG_PHYCTL_A33, |
577 | 573 | .dedicated_clocks = true, |
578 | - .enable_pmu_unk1 = false, | |
579 | 574 | }; |
580 | 575 | |
581 | 576 | static const struct sun4i_usb_phy_cfg sun8i_a83t_cfg = { |
@@ -591,7 +586,7 @@ static const struct sun4i_usb_phy_cfg sun8i_h3_cfg = { | ||
591 | 586 | .disc_thresh = 3, |
592 | 587 | .phyctl_offset = REG_PHYCTL_A33, |
593 | 588 | .dedicated_clocks = true, |
594 | - .enable_pmu_unk1 = true, | |
589 | + .hci_phy_ctl_clear = PHY_CTL_H3_SIDDQ, | |
595 | 590 | .phy0_dual_route = true, |
596 | 591 | }; |
597 | 592 |
@@ -601,7 +596,7 @@ static const struct sun4i_usb_phy_cfg sun8i_r40_cfg = { | ||
601 | 596 | .disc_thresh = 3, |
602 | 597 | .phyctl_offset = REG_PHYCTL_A33, |
603 | 598 | .dedicated_clocks = true, |
604 | - .enable_pmu_unk1 = true, | |
599 | + .hci_phy_ctl_clear = PHY_CTL_H3_SIDDQ, | |
605 | 600 | .phy0_dual_route = true, |
606 | 601 | }; |
607 | 602 |
@@ -611,7 +606,16 @@ static const struct sun4i_usb_phy_cfg sun8i_v3s_cfg = { | ||
611 | 606 | .disc_thresh = 3, |
612 | 607 | .phyctl_offset = REG_PHYCTL_A33, |
613 | 608 | .dedicated_clocks = true, |
614 | - .enable_pmu_unk1 = true, | |
609 | + .hci_phy_ctl_clear = PHY_CTL_H3_SIDDQ, | |
610 | + .phy0_dual_route = true, | |
611 | +}; | |
612 | + | |
613 | +static const struct sun4i_usb_phy_cfg sun20i_d1_cfg = { | |
614 | + .num_phys = 2, | |
615 | + .type = sun50i_h6_phy, | |
616 | + .phyctl_offset = REG_PHYCTL_A33, | |
617 | + .dedicated_clocks = true, | |
618 | + .hci_phy_ctl_clear = PHY_CTL_SIDDQ, | |
615 | 619 | .phy0_dual_route = true, |
616 | 620 | }; |
617 | 621 |
@@ -621,7 +625,7 @@ static const struct sun4i_usb_phy_cfg sun50i_a64_cfg = { | ||
621 | 625 | .disc_thresh = 3, |
622 | 626 | .phyctl_offset = REG_PHYCTL_A33, |
623 | 627 | .dedicated_clocks = true, |
624 | - .enable_pmu_unk1 = true, | |
628 | + .hci_phy_ctl_clear = PHY_CTL_H3_SIDDQ, | |
625 | 629 | .phy0_dual_route = true, |
626 | 630 | }; |
627 | 631 |
@@ -631,7 +635,6 @@ static const struct sun4i_usb_phy_cfg sun50i_h6_cfg = { | ||
631 | 635 | .disc_thresh = 3, |
632 | 636 | .phyctl_offset = REG_PHYCTL_A33, |
633 | 637 | .dedicated_clocks = true, |
634 | - .enable_pmu_unk1 = true, | |
635 | 638 | .phy0_dual_route = true, |
636 | 639 | .missing_phys = BIT(1) | BIT(2), |
637 | 640 | }; |
@@ -647,6 +650,7 @@ static const struct udevice_id sun4i_usb_phy_ids[] = { | ||
647 | 650 | { .compatible = "allwinner,sun8i-h3-usb-phy", .data = (ulong)&sun8i_h3_cfg }, |
648 | 651 | { .compatible = "allwinner,sun8i-r40-usb-phy", .data = (ulong)&sun8i_r40_cfg }, |
649 | 652 | { .compatible = "allwinner,sun8i-v3s-usb-phy", .data = (ulong)&sun8i_v3s_cfg }, |
653 | + { .compatible = "allwinner,sun20i-d1-usb-phy", .data = (ulong)&sun20i_d1_cfg }, | |
650 | 654 | { .compatible = "allwinner,sun50i-a64-usb-phy", .data = (ulong)&sun50i_a64_cfg}, |
651 | 655 | { .compatible = "allwinner,sun50i-h6-usb-phy", .data = (ulong)&sun50i_h6_cfg}, |
652 | 656 | { } |
@@ -12,30 +12,22 @@ | ||
12 | 12 | #include <reset-uclass.h> |
13 | 13 | #include <asm/io.h> |
14 | 14 | #include <clk/sunxi.h> |
15 | -#include <dm/device-internal.h> | |
16 | -#include <dm/lists.h> | |
17 | 15 | #include <linux/bitops.h> |
18 | 16 | #include <linux/log2.h> |
19 | 17 | |
20 | -struct sunxi_reset_priv { | |
21 | - void *base; | |
22 | - ulong count; | |
23 | - const struct ccu_desc *desc; | |
24 | -}; | |
25 | - | |
26 | -static const struct ccu_reset *priv_to_reset(struct sunxi_reset_priv *priv, | |
18 | +static const struct ccu_reset *plat_to_reset(struct ccu_plat *plat, | |
27 | 19 | unsigned long id) |
28 | 20 | { |
29 | - return &priv->desc->resets[id]; | |
21 | + return &plat->desc->resets[id]; | |
30 | 22 | } |
31 | 23 | |
32 | 24 | static int sunxi_reset_request(struct reset_ctl *reset_ctl) |
33 | 25 | { |
34 | - struct sunxi_reset_priv *priv = dev_get_priv(reset_ctl->dev); | |
26 | + struct ccu_plat *plat = dev_get_plat(reset_ctl->dev); | |
35 | 27 | |
36 | 28 | debug("%s: (RST#%ld)\n", __func__, reset_ctl->id); |
37 | 29 | |
38 | - if (reset_ctl->id >= priv->count) | |
30 | + if (reset_ctl->id >= plat->desc->num_resets) | |
39 | 31 | return -EINVAL; |
40 | 32 | |
41 | 33 | return 0; |
@@ -43,8 +35,8 @@ static int sunxi_reset_request(struct reset_ctl *reset_ctl) | ||
43 | 35 | |
44 | 36 | static int sunxi_set_reset(struct reset_ctl *reset_ctl, bool on) |
45 | 37 | { |
46 | - struct sunxi_reset_priv *priv = dev_get_priv(reset_ctl->dev); | |
47 | - const struct ccu_reset *reset = priv_to_reset(priv, reset_ctl->id); | |
38 | + struct ccu_plat *plat = dev_get_plat(reset_ctl->dev); | |
39 | + const struct ccu_reset *reset = plat_to_reset(plat, reset_ctl->id); | |
48 | 40 | u32 reg; |
49 | 41 | |
50 | 42 | if (!(reset->flags & CCU_RST_F_IS_VALID)) { |
@@ -55,13 +47,13 @@ static int sunxi_set_reset(struct reset_ctl *reset_ctl, bool on) | ||
55 | 47 | debug("%s: (RST#%ld) off#0x%x, BIT(%d)\n", __func__, |
56 | 48 | reset_ctl->id, reset->off, ilog2(reset->bit)); |
57 | 49 | |
58 | - reg = readl(priv->base + reset->off); | |
50 | + reg = readl(plat->base + reset->off); | |
59 | 51 | if (on) |
60 | 52 | reg |= reset->bit; |
61 | 53 | else |
62 | 54 | reg &= ~reset->bit; |
63 | 55 | |
64 | - writel(reg, priv->base + reset->off); | |
56 | + writel(reg, plat->base + reset->off); | |
65 | 57 | |
66 | 58 | return 0; |
67 | 59 | } |
@@ -82,39 +74,8 @@ struct reset_ops sunxi_reset_ops = { | ||
82 | 74 | .rst_deassert = sunxi_reset_deassert, |
83 | 75 | }; |
84 | 76 | |
85 | -static int sunxi_reset_probe(struct udevice *dev) | |
86 | -{ | |
87 | - struct sunxi_reset_priv *priv = dev_get_priv(dev); | |
88 | - | |
89 | - priv->base = dev_read_addr_ptr(dev); | |
90 | - | |
91 | - return 0; | |
92 | -} | |
93 | - | |
94 | -int sunxi_reset_bind(struct udevice *dev, ulong count) | |
95 | -{ | |
96 | - struct udevice *rst_dev; | |
97 | - struct sunxi_reset_priv *priv; | |
98 | - int ret; | |
99 | - | |
100 | - ret = device_bind_driver_to_node(dev, "sunxi_reset", "reset", | |
101 | - dev_ofnode(dev), &rst_dev); | |
102 | - if (ret) { | |
103 | - debug("failed to bind sunxi_reset driver (ret=%d)\n", ret); | |
104 | - return ret; | |
105 | - } | |
106 | - priv = malloc(sizeof(struct sunxi_reset_priv)); | |
107 | - priv->count = count; | |
108 | - priv->desc = (const struct ccu_desc *)dev_get_driver_data(dev); | |
109 | - dev_set_priv(rst_dev, priv); | |
110 | - | |
111 | - return 0; | |
112 | -} | |
113 | - | |
114 | 77 | U_BOOT_DRIVER(sunxi_reset) = { |
115 | 78 | .name = "sunxi_reset", |
116 | 79 | .id = UCLASS_RESET, |
117 | 80 | .ops = &sunxi_reset_ops, |
118 | - .probe = sunxi_reset_probe, | |
119 | - .priv_auto = sizeof(struct sunxi_reset_priv), | |
120 | 81 | }; |
@@ -72,10 +72,18 @@ DECLARE_GLOBAL_DATA_PTR; | ||
72 | 72 | #define SUN4I_XMIT_CNT(cnt) ((cnt) & SUN4I_MAX_XFER_SIZE) |
73 | 73 | #define SUN4I_FIFO_STA_RF_CNT_BITS 0 |
74 | 74 | |
75 | -#define SUN4I_SPI_MAX_RATE 24000000 | |
75 | +#ifdef CONFIG_MACH_SUNIV | |
76 | +/* the AHB clock, which we programmed to be 1/3 of PLL_PERIPH@600MHz */ | |
77 | +#define SUNXI_INPUT_CLOCK 200000000 /* 200 MHz */ | |
78 | +#define SUN4I_SPI_MAX_RATE (SUNXI_INPUT_CLOCK / 2) | |
79 | +#else | |
80 | +/* the SPI mod clock, defaulting to be 1/1 of the HOSC@24MHz */ | |
81 | +#define SUNXI_INPUT_CLOCK 24000000 /* 24 MHz */ | |
82 | +#define SUN4I_SPI_MAX_RATE SUNXI_INPUT_CLOCK | |
83 | +#endif | |
76 | 84 | #define SUN4I_SPI_MIN_RATE 3000 |
77 | 85 | #define SUN4I_SPI_DEFAULT_RATE 1000000 |
78 | -#define SUN4I_SPI_TIMEOUT_US 1000000 | |
86 | +#define SUN4I_SPI_TIMEOUT_MS 1000 | |
79 | 87 | |
80 | 88 | #define SPI_REG(priv, reg) ((priv)->base + \ |
81 | 89 | (priv)->variant->regs[reg]) |
@@ -221,6 +229,60 @@ err_ahb: | ||
221 | 229 | return ret; |
222 | 230 | } |
223 | 231 | |
232 | +static void sun4i_spi_set_speed_mode(struct udevice *dev) | |
233 | +{ | |
234 | + struct sun4i_spi_priv *priv = dev_get_priv(dev); | |
235 | + unsigned int div; | |
236 | + u32 reg; | |
237 | + | |
238 | + /* | |
239 | + * Setup clock divider. | |
240 | + * | |
241 | + * We have two choices there. Either we can use the clock | |
242 | + * divide rate 1, which is calculated thanks to this formula: | |
243 | + * SPI_CLK = MOD_CLK / (2 ^ (cdr + 1)) | |
244 | + * Or we can use CDR2, which is calculated with the formula: | |
245 | + * SPI_CLK = MOD_CLK / (2 * (cdr + 1)) | |
246 | + * Whether we use the former or the latter is set through the | |
247 | + * DRS bit. | |
248 | + * | |
249 | + * First try CDR2, and if we can't reach the expected | |
250 | + * frequency, fall back to CDR1. | |
251 | + */ | |
252 | + | |
253 | + div = DIV_ROUND_UP(SUNXI_INPUT_CLOCK, priv->freq); | |
254 | + reg = readl(SPI_REG(priv, SPI_CCR)); | |
255 | + | |
256 | + if ((div / 2) <= (SUN4I_CLK_CTL_CDR2_MASK + 1)) { | |
257 | + div /= 2; | |
258 | + if (div > 0) | |
259 | + div--; | |
260 | + | |
261 | + reg &= ~(SUN4I_CLK_CTL_CDR2_MASK | SUN4I_CLK_CTL_DRS); | |
262 | + reg |= SUN4I_CLK_CTL_CDR2(div) | SUN4I_CLK_CTL_DRS; | |
263 | + } else { | |
264 | + div = fls(div - 1); | |
265 | + /* The F1C100s encodes the divider as 2^(n+1) */ | |
266 | + if (IS_ENABLED(CONFIG_MACH_SUNIV)) | |
267 | + div--; | |
268 | + reg &= ~((SUN4I_CLK_CTL_CDR1_MASK << 8) | SUN4I_CLK_CTL_DRS); | |
269 | + reg |= SUN4I_CLK_CTL_CDR1(div); | |
270 | + } | |
271 | + | |
272 | + writel(reg, SPI_REG(priv, SPI_CCR)); | |
273 | + | |
274 | + reg = readl(SPI_REG(priv, SPI_TCR)); | |
275 | + reg &= ~(SPI_BIT(priv, SPI_TCR_CPOL) | SPI_BIT(priv, SPI_TCR_CPHA)); | |
276 | + | |
277 | + if (priv->mode & SPI_CPOL) | |
278 | + reg |= SPI_BIT(priv, SPI_TCR_CPOL); | |
279 | + | |
280 | + if (priv->mode & SPI_CPHA) | |
281 | + reg |= SPI_BIT(priv, SPI_TCR_CPHA); | |
282 | + | |
283 | + writel(reg, SPI_REG(priv, SPI_TCR)); | |
284 | +} | |
285 | + | |
224 | 286 | static int sun4i_spi_claim_bus(struct udevice *dev) |
225 | 287 | { |
226 | 288 | struct sun4i_spi_priv *priv = dev_get_priv(dev->parent); |
@@ -240,6 +302,8 @@ static int sun4i_spi_claim_bus(struct udevice *dev) | ||
240 | 302 | setbits_le32(SPI_REG(priv, SPI_TCR), SPI_BIT(priv, SPI_TCR_CS_MANUAL) | |
241 | 303 | SPI_BIT(priv, SPI_TCR_CS_ACTIVE_LOW)); |
242 | 304 | |
305 | + sun4i_spi_set_speed_mode(dev->parent); | |
306 | + | |
243 | 307 | return 0; |
244 | 308 | } |
245 | 309 |
@@ -262,7 +326,6 @@ static int sun4i_spi_xfer(struct udevice *dev, unsigned int bitlen, | ||
262 | 326 | struct dm_spi_slave_plat *slave_plat = dev_get_parent_plat(dev); |
263 | 327 | |
264 | 328 | u32 len = bitlen / 8; |
265 | - u32 rx_fifocnt; | |
266 | 329 | u8 nbytes; |
267 | 330 | int ret; |
268 | 331 |
@@ -300,13 +363,10 @@ static int sun4i_spi_xfer(struct udevice *dev, unsigned int bitlen, | ||
300 | 363 | setbits_le32(SPI_REG(priv, SPI_TCR), |
301 | 364 | SPI_BIT(priv, SPI_TCR_XCH)); |
302 | 365 | |
303 | - /* Wait till RX FIFO to be empty */ | |
304 | - ret = readl_poll_timeout(SPI_REG(priv, SPI_FSR), | |
305 | - rx_fifocnt, | |
306 | - (((rx_fifocnt & | |
307 | - SPI_BIT(priv, SPI_FSR_RF_CNT_MASK)) >> | |
308 | - SUN4I_FIFO_STA_RF_CNT_BITS) >= nbytes), | |
309 | - SUN4I_SPI_TIMEOUT_US); | |
366 | + /* Wait for the transfer to be done */ | |
367 | + ret = wait_for_bit_le32((const void *)SPI_REG(priv, SPI_TCR), | |
368 | + SPI_BIT(priv, SPI_TCR_XCH), | |
369 | + false, SUN4I_SPI_TIMEOUT_MS, false); | |
310 | 370 | if (ret < 0) { |
311 | 371 | printf("ERROR: sun4i_spi: Timeout transferring data\n"); |
312 | 372 | sun4i_spi_set_cs(bus, slave_plat->cs, false); |
@@ -329,46 +389,14 @@ static int sun4i_spi_set_speed(struct udevice *dev, uint speed) | ||
329 | 389 | { |
330 | 390 | struct sun4i_spi_plat *plat = dev_get_plat(dev); |
331 | 391 | struct sun4i_spi_priv *priv = dev_get_priv(dev); |
332 | - unsigned int div; | |
333 | - u32 reg; | |
334 | 392 | |
335 | 393 | if (speed > plat->max_hz) |
336 | 394 | speed = plat->max_hz; |
337 | 395 | |
338 | 396 | if (speed < SUN4I_SPI_MIN_RATE) |
339 | 397 | speed = SUN4I_SPI_MIN_RATE; |
340 | - /* | |
341 | - * Setup clock divider. | |
342 | - * | |
343 | - * We have two choices there. Either we can use the clock | |
344 | - * divide rate 1, which is calculated thanks to this formula: | |
345 | - * SPI_CLK = MOD_CLK / (2 ^ (cdr + 1)) | |
346 | - * Or we can use CDR2, which is calculated with the formula: | |
347 | - * SPI_CLK = MOD_CLK / (2 * (cdr + 1)) | |
348 | - * Whether we use the former or the latter is set through the | |
349 | - * DRS bit. | |
350 | - * | |
351 | - * First try CDR2, and if we can't reach the expected | |
352 | - * frequency, fall back to CDR1. | |
353 | - */ | |
354 | - | |
355 | - div = SUN4I_SPI_MAX_RATE / (2 * speed); | |
356 | - reg = readl(SPI_REG(priv, SPI_CCR)); | |
357 | - | |
358 | - if (div <= (SUN4I_CLK_CTL_CDR2_MASK + 1)) { | |
359 | - if (div > 0) | |
360 | - div--; | |
361 | - | |
362 | - reg &= ~(SUN4I_CLK_CTL_CDR2_MASK | SUN4I_CLK_CTL_DRS); | |
363 | - reg |= SUN4I_CLK_CTL_CDR2(div) | SUN4I_CLK_CTL_DRS; | |
364 | - } else { | |
365 | - div = __ilog2(SUN4I_SPI_MAX_RATE) - __ilog2(speed); | |
366 | - reg &= ~((SUN4I_CLK_CTL_CDR1_MASK << 8) | SUN4I_CLK_CTL_DRS); | |
367 | - reg |= SUN4I_CLK_CTL_CDR1(div); | |
368 | - } | |
369 | 398 | |
370 | 399 | priv->freq = speed; |
371 | - writel(reg, SPI_REG(priv, SPI_CCR)); | |
372 | 400 | |
373 | 401 | return 0; |
374 | 402 | } |
@@ -376,19 +404,8 @@ static int sun4i_spi_set_speed(struct udevice *dev, uint speed) | ||
376 | 404 | static int sun4i_spi_set_mode(struct udevice *dev, uint mode) |
377 | 405 | { |
378 | 406 | struct sun4i_spi_priv *priv = dev_get_priv(dev); |
379 | - u32 reg; | |
380 | - | |
381 | - reg = readl(SPI_REG(priv, SPI_TCR)); | |
382 | - reg &= ~(SPI_BIT(priv, SPI_TCR_CPOL) | SPI_BIT(priv, SPI_TCR_CPHA)); | |
383 | - | |
384 | - if (mode & SPI_CPOL) | |
385 | - reg |= SPI_BIT(priv, SPI_TCR_CPOL); | |
386 | - | |
387 | - if (mode & SPI_CPHA) | |
388 | - reg |= SPI_BIT(priv, SPI_TCR_CPHA); | |
389 | 407 | |
390 | 408 | priv->mode = mode; |
391 | - writel(reg, SPI_REG(priv, SPI_TCR)); | |
392 | 409 | |
393 | 410 | return 0; |
394 | 411 | } |
@@ -70,34 +70,21 @@ struct ccu_reset { | ||
70 | 70 | struct ccu_desc { |
71 | 71 | const struct ccu_clk_gate *gates; |
72 | 72 | const struct ccu_reset *resets; |
73 | + u8 num_gates; | |
74 | + u8 num_resets; | |
73 | 75 | }; |
74 | 76 | |
75 | 77 | /** |
76 | - * struct ccu_priv - sunxi clock control unit | |
78 | + * struct ccu_plat - sunxi clock control unit platform data | |
77 | 79 | * |
78 | 80 | * @base: base address |
79 | 81 | * @desc: ccu descriptor |
80 | 82 | */ |
81 | -struct ccu_priv { | |
83 | +struct ccu_plat { | |
82 | 84 | void *base; |
83 | 85 | const struct ccu_desc *desc; |
84 | 86 | }; |
85 | 87 | |
86 | -/** | |
87 | - * sunxi_clk_probe - common sunxi clock probe | |
88 | - * @dev: clock device | |
89 | - */ | |
90 | -int sunxi_clk_probe(struct udevice *dev); | |
91 | - | |
92 | 88 | extern struct clk_ops sunxi_clk_ops; |
93 | 89 | |
94 | -/** | |
95 | - * sunxi_reset_bind() - reset binding | |
96 | - * | |
97 | - * @dev: reset device | |
98 | - * @count: reset count | |
99 | - * Return: 0 success, or error value | |
100 | - */ | |
101 | -int sunxi_reset_bind(struct udevice *dev, ulong count); | |
102 | - | |
103 | 90 | #endif /* _CLK_SUNXI_H */ |
@@ -2,18 +2,12 @@ | ||
2 | 2 | /* |
3 | 3 | * (C) Copyright 2012-2013 Henrik Nordstrom <henrik@henriknordstrom.net> |
4 | 4 | * |
5 | - * Configuration settings for the Allwinner A10 (sun4i) CPU | |
5 | + * Placeholder wrapper to allow addressing Allwinner A10 (sun4i) CPU | |
6 | + * based devices separately. Please do not add anything in here. | |
6 | 7 | */ |
7 | 8 | #ifndef __CONFIG_H |
8 | 9 | #define __CONFIG_H |
9 | 10 | |
10 | -/* | |
11 | - * A10 specific configuration | |
12 | - */ | |
13 | - | |
14 | -/* | |
15 | - * Include common sunxi configuration where most the settings are | |
16 | - */ | |
17 | 11 | #include <configs/sunxi-common.h> |
18 | 12 | |
19 | 13 | #endif /* __CONFIG_H */ |
@@ -1,26 +1,11 @@ | ||
1 | 1 | /* SPDX-License-Identifier: GPL-2.0+ */ |
2 | 2 | /* |
3 | - * Configuration settings for the Allwinner A64 (sun50i) CPU | |
3 | + * Placeholder wrapper to allow addressing Allwinner A64 (and later) sun50i | |
4 | + * CPU based devices separately. Please do not add anything in here. | |
4 | 5 | */ |
5 | - | |
6 | 6 | #ifndef __CONFIG_H |
7 | 7 | #define __CONFIG_H |
8 | 8 | |
9 | -/* | |
10 | - * A64 specific configuration | |
11 | - */ | |
12 | - | |
13 | -#ifndef CONFIG_SUN50I_GEN_H6 | |
14 | -#define GICD_BASE 0x1c81000 | |
15 | -#define GICC_BASE 0x1c82000 | |
16 | -#else | |
17 | -#define GICD_BASE 0x3021000 | |
18 | -#define GICC_BASE 0x3022000 | |
19 | -#endif | |
20 | - | |
21 | -/* | |
22 | - * Include common sunxi configuration where most the settings are | |
23 | - */ | |
24 | 9 | #include <configs/sunxi-common.h> |
25 | 10 | |
26 | 11 | #endif /* __CONFIG_H */ |
@@ -2,18 +2,12 @@ | ||
2 | 2 | /* |
3 | 3 | * (C) Copyright 2012-2013 Henrik Nordstrom <henrik@henriknordstrom.net> |
4 | 4 | * |
5 | - * Configuration settings for the Allwinner A13 (sun5i) CPU | |
5 | + * Placeholder wrapper to allow addressing Allwinner A13 (sun5i) CPU | |
6 | + * based devices separately. Please do not add anything in here. | |
6 | 7 | */ |
7 | 8 | #ifndef __CONFIG_H |
8 | 9 | #define __CONFIG_H |
9 | 10 | |
10 | -/* | |
11 | - * High Level Configuration Options | |
12 | - */ | |
13 | - | |
14 | -/* | |
15 | - * Include common sunxi configuration where most the settings are | |
16 | - */ | |
17 | 11 | #include <configs/sunxi-common.h> |
18 | 12 | |
19 | 13 | #endif /* __CONFIG_H */ |
@@ -4,15 +4,12 @@ | ||
4 | 4 | * (C) Copyright 2013 Luke Kenneth Casson Leighton <lkcl@lkcl.net> |
5 | 5 | * (C) Copyright 2013 Maxime Ripard <maxime.ripard@free-electrons.com> |
6 | 6 | * |
7 | - * Configuration settings for the Allwinner A31 (sun6i) CPU | |
7 | + * Placeholder wrapper to allow addressing Allwinner A31 (sun6i) CPU | |
8 | + * based devices separately. Please do not add anything in here. | |
8 | 9 | */ |
9 | - | |
10 | 10 | #ifndef __CONFIG_H |
11 | 11 | #define __CONFIG_H |
12 | 12 | |
13 | -/* | |
14 | - * Include common sunxi configuration where most the settings are | |
15 | - */ | |
16 | 13 | #include <configs/sunxi-common.h> |
17 | 14 | |
18 | 15 | #endif /* __CONFIG_H */ |
@@ -3,14 +3,12 @@ | ||
3 | 3 | * (C) Copyright 2012-2013 Henrik Nordstrom <henrik@henriknordstrom.net> |
4 | 4 | * (C) Copyright 2013 Luke Kenneth Casson Leighton <lkcl@lkcl.net> |
5 | 5 | * |
6 | - * Configuration settings for the Allwinner A20 (sun7i) CPU | |
6 | + * Placeholder wrapper to allow addressing Allwinner A20 (sun7i) CPU | |
7 | + * based devices separately. Please do not add anything in here. | |
7 | 8 | */ |
8 | 9 | #ifndef __CONFIG_H |
9 | 10 | #define __CONFIG_H |
10 | 11 | |
11 | -/* | |
12 | - * Include common sunxi configuration where most the settings are | |
13 | - */ | |
14 | 12 | #include <configs/sunxi-common.h> |
15 | 13 | |
16 | 14 | #endif /* __CONFIG_H */ |
@@ -2,21 +2,12 @@ | ||
2 | 2 | /* |
3 | 3 | * (C) Copyright 2014 Chen-Yu Tsai <wens@csie.org> |
4 | 4 | * |
5 | - * Configuration settings for the Allwinner A23 (sun8i) CPU | |
5 | + * Placeholder wrapper to allow addressing Allwinner A23 (and later) sun8i | |
6 | + * CPU based devices separately. Please do not add anything in here. | |
6 | 7 | */ |
7 | - | |
8 | 8 | #ifndef __CONFIG_H |
9 | 9 | #define __CONFIG_H |
10 | 10 | |
11 | -/* | |
12 | - * A23 specific configuration | |
13 | - */ | |
14 | - | |
15 | -#include <asm/arch/cpu.h> | |
16 | - | |
17 | -/* | |
18 | - * Include common sunxi configuration where most the settings are | |
19 | - */ | |
20 | 11 | #include <configs/sunxi-common.h> |
21 | 12 | |
22 | 13 | #endif /* __CONFIG_H */ |
@@ -2,19 +2,12 @@ | ||
2 | 2 | /* |
3 | 3 | * (C) Copyright 2015 Hans de Goede <hdegoede@redhat.com> |
4 | 4 | * |
5 | - * Configuration settings for the Allwinner A80 (sun9i) CPU | |
5 | + * Placeholder wrapper to allow addressing Allwinner A80 (sun9i) CPU | |
6 | + * based devices separately. Please do not add anything in here. | |
6 | 7 | */ |
7 | - | |
8 | 8 | #ifndef __CONFIG_H |
9 | 9 | #define __CONFIG_H |
10 | 10 | |
11 | -/* | |
12 | - * A80 specific configuration | |
13 | - */ | |
14 | - | |
15 | -/* | |
16 | - * Include common sunxi configuration where most the settings are | |
17 | - */ | |
18 | 11 | #include <configs/sunxi-common.h> |
19 | 12 | |
20 | 13 | #endif /* __CONFIG_H */ |
@@ -1,14 +1,11 @@ | ||
1 | 1 | /* SPDX-License-Identifier: GPL-2.0+ */ |
2 | 2 | /* |
3 | - * Configuration settings for new Allwinner F-series (suniv) CPU | |
3 | + * Placeholder wrapper to allow addressing Allwinner F-series (suniv) CPU | |
4 | + * based devices separately. Please do not add anything in here. | |
4 | 5 | */ |
5 | - | |
6 | 6 | #ifndef __CONFIG_H |
7 | 7 | #define __CONFIG_H |
8 | 8 | |
9 | -/* | |
10 | - * Include common sunxi configuration where most the settings are | |
11 | - */ | |
12 | 9 | #include <configs/sunxi-common.h> |
13 | 10 | |
14 | 11 | #endif /* __CONFIG_H */ |