files.sunxi revision 1.55
1#	$NetBSD: files.sunxi,v 1.55 2018/05/10 00:00:21 jmcneill Exp $
2#
3# Configuration info for Allwinner sunxi family SoCs
4#
5#
6
7file	arch/arm/sunxi/sunxi_platform.c		soc_sunxi
8
9# CCU
10define	sunxi_ccu
11file	arch/arm/sunxi/sunxi_ccu.c		sunxi_ccu
12file	arch/arm/sunxi/sunxi_ccu_div.c		sunxi_ccu
13file	arch/arm/sunxi/sunxi_ccu_fixed_factor.c	sunxi_ccu
14file	arch/arm/sunxi/sunxi_ccu_fractional.c	sunxi_ccu
15file	arch/arm/sunxi/sunxi_ccu_gate.c		sunxi_ccu
16file	arch/arm/sunxi/sunxi_ccu_nm.c		sunxi_ccu
17file	arch/arm/sunxi/sunxi_ccu_nkmp.c		sunxi_ccu
18file	arch/arm/sunxi/sunxi_ccu_phase.c	sunxi_ccu
19file	arch/arm/sunxi/sunxi_ccu_prediv.c	sunxi_ccu
20file	arch/arm/sunxi/sunxi_ccu_display.c	sunxi_ccu
21
22# CCU (A10/A20)
23device	sun4ia10ccu: sunxi_ccu
24attach	sun4ia10ccu at fdt with sunxi_a10_ccu
25file	arch/arm/sunxi/sun4i_a10_ccu.c		sunxi_a10_ccu
26
27# CCU (A13)
28device	sun5ia13ccu: sunxi_ccu
29attach	sun5ia13ccu at fdt with sunxi_a13_ccu
30file	arch/arm/sunxi/sun5i_a13_ccu.c		sunxi_a13_ccu
31
32# CCU (A31)
33device	sun6ia31ccu: sunxi_ccu
34attach	sun6ia31ccu at fdt with sunxi_a31_ccu
35file	arch/arm/sunxi/sun6i_a31_ccu.c		sunxi_a31_ccu
36
37# CCU (A83T)
38device	sun8ia83tccu: sunxi_ccu
39attach	sun8ia83tccu at fdt with sunxi_a83t_ccu
40file	arch/arm/sunxi/sun8i_a83t_ccu.c		sunxi_a83t_ccu
41
42# CCU (H3)
43device	sun8ih3ccu: sunxi_ccu
44attach	sun8ih3ccu at fdt with sunxi_h3_ccu
45file	arch/arm/sunxi/sun8i_h3_ccu.c		sunxi_h3_ccu
46
47# CCU (H3 PRCM)
48device	sun8ih3rccu: sunxi_ccu
49attach	sun8ih3rccu at fdt with sunxi_h3_r_ccu
50file	arch/arm/sunxi/sun8i_h3_r_ccu.c		sunxi_h3_r_ccu
51
52# CCU (A80)
53device	sun9ia80ccu: sunxi_ccu
54attach	sun9ia80ccu at fdt with sunxi_a80_ccu
55file	arch/arm/sunxi/sun9i_a80_ccu.c		sunxi_a80_ccu
56
57# CCU (A64)
58device	sun50ia64ccu: sunxi_ccu
59attach	sun50ia64ccu at fdt with sunxi_a64_ccu
60file	arch/arm/sunxi/sun50i_a64_ccu.c		sunxi_a64_ccu
61
62# CCU (A64 PRCM)
63device	sun50ia64rccu: sunxi_ccu
64attach	sun50ia64rccu at fdt with sunxi_a64_r_ccu
65file	arch/arm/sunxi/sun50i_a64_r_ccu.c	sunxi_a64_r_ccu
66
67# CCU (H6)
68device	sun50ih6ccu: sunxi_ccu
69attach	sun50ih6ccu at fdt with sunxi_h6_ccu
70file	arch/arm/sunxi/sun50i_h6_ccu.c		sunxi_h6_ccu
71
72# CCU (H6 PRCM)
73device	sun50ih6rccu: sunxi_ccu
74attach	sun50ih6rccu at fdt with sunxi_h6_r_ccu
75file	arch/arm/sunxi/sun50i_h6_r_ccu.c	sunxi_h6_r_ccu
76
77# Misc. clock resets
78device	sunxiresets
79attach	sunxiresets at fdt with sunxi_resets
80file	arch/arm/sunxi/sunxi_resets.c		sunxi_resets
81
82# Misc. clock gates
83device	sunxigates
84attach	sunxigates at fdt with sunxi_gates
85file	arch/arm/sunxi/sunxi_gates.c		sunxi_gates
86
87# GMAC MII/RGMII clock mux
88device	sunxigmacclk
89attach	sunxigmacclk at fdt with sunxi_gmacclk
90file	arch/arm/sunxi/sunxi_gmacclk.c		sunxi_gmacclk
91
92# SD/MMC-COMM (A80)
93device	sun9immcclk
94attach	sun9immcclk at fdt with sunxi_a80_mmcclk
95file	arch/arm/sunxi/sun9i_a80_mmcclk.c	sunxi_a80_mmcclk
96
97# Interrupt controller
98device	sunxiintc: pic, pic_splfuncs
99attach	sunxiintc at fdt with sunxi_intc
100file	arch/arm/sunxi/sunxi_intc.c		sunxi_intc
101
102device	sunxinmi
103attach	sunxinmi at fdt with sunxi_nmi
104file	arch/arm/sunxi/sunxi_nmi.c		sunxi_nmi
105
106# GPIO
107device	sunxigpio: gpiobus
108attach	sunxigpio at fdt with sunxi_gpio
109file	arch/arm/sunxi/sunxi_gpio.c		sunxi_gpio
110file	arch/arm/sunxi/sun4i_a10_gpio.c		sunxi_gpio & soc_sun4i_a10
111file	arch/arm/sunxi/sun5i_a13_gpio.c		sunxi_gpio & soc_sun5i_a13
112file	arch/arm/sunxi/sun6i_a31_gpio.c		sunxi_gpio & soc_sun6i_a31
113file	arch/arm/sunxi/sun7i_a20_gpio.c		sunxi_gpio & soc_sun7i_a20
114file	arch/arm/sunxi/sun8i_a83t_gpio.c	sunxi_gpio & soc_sun8i_a83t
115file	arch/arm/sunxi/sun8i_h3_gpio.c		sunxi_gpio & soc_sun8i_h3
116file	arch/arm/sunxi/sun9i_a80_gpio.c		sunxi_gpio & soc_sun9i_a80
117file	arch/arm/sunxi/sun50i_a64_gpio.c	sunxi_gpio & soc_sun50i_a64
118file	arch/arm/sunxi/sun50i_h6_gpio.c		sunxi_gpio & soc_sun50i_h6
119
120# UART
121attach	com at fdt with sunxi_com
122file	arch/arm/sunxi/sunxi_com.c		sunxi_com needs-flag
123
124# PWM
125device	sunxipwm: pwm
126attach	sunxipwm at fdt with sunxi_pwm
127file	arch/arm/sunxi/sunxi_pwm.c		sunxi_pwm
128
129# SD/MMC
130device	sunximmc: sdmmcbus
131attach	sunximmc at fdt with sunxi_mmc
132file	arch/arm/sunxi/sunxi_mmc.c		sunxi_mmc
133defparam opt_sunximmc.h				SUNXI_MMC_DEBUG
134
135# USB PHY
136device	sunxiusbphy
137attach	sunxiusbphy at fdt with sunxi_usbphy
138file	arch/arm/sunxi/sunxi_usbphy.c		sunxi_usbphy
139
140device	sunxiusb3phy
141attach	sunxiusb3phy at fdt with sunxi_usb3phy
142file	arch/arm/sunxi/sunxi_usb3phy.c		sunxi_usb3phy
143
144# EHCI
145attach	ehci at fdt with ehci_fdt
146file	dev/fdt/ehci_fdt.c			ehci_fdt	
147
148# OHCI
149attach	ohci at fdt with ohci_fdt
150file	dev/fdt/ohci_fdt.c			ohci_fdt
151
152# TWI
153device	sunxitwi: i2cbus, i2cexec, mvi2c
154attach	sunxitwi at fdt with sunxi_twi
155file	arch/arm/sunxi/sunxi_twi.c		sunxi_twi
156
157# P2WI/RSB
158device	sunxirsb: i2cbus, i2cexec
159attach	sunxirsb at fdt with sunxi_rsb
160file	arch/arm/sunxi/sunxi_rsb.c		sunxi_rsb
161
162# RTC
163device	sunxirtc
164attach	sunxirtc at fdt with sunxi_rtc
165file	arch/arm/sunxi/sunxi_rtc.c		sunxi_rtc
166
167# EMAC (common)
168device	emac: arp, ether, ifnet, mii
169
170# EMAC (sun4i/sun5i/sun7i)
171ifdef arm
172attach	emac at fdt with sun4i_emac
173file	arch/arm/sunxi/sun4i_emac.c		sun4i_emac
174endif
175
176# EMAC (sun8i/sun50i)
177attach	emac at fdt with sunxi_emac
178file	arch/arm/sunxi/sunxi_emac.c		sunxi_emac
179
180# GMAC
181attach	awge at fdt with sunxi_gmac
182file	arch/arm/sunxi/sunxi_gmac.c		sunxi_gmac
183
184# Timer
185device	sunxitimer
186attach	sunxitimer at fdt with sunxi_timer
187file	arch/arm/sunxi/sunxi_timer.c		sunxi_timer
188
189# Watchdog
190device	sunxiwdt: sysmon_wdog
191attach	sunxiwdt at fdt with sunxi_wdt
192file	arch/arm/sunxi/sunxi_wdt.c		sunxi_wdt
193
194# DMA controller (sun4i)
195device	sun4idma
196attach	sun4idma at fdt with sun4i_dma
197file	arch/arm/sunxi/sun4i_dma.c		sun4i_dma
198
199# DMA controller (sun6i)
200device	sun6idma
201attach	sun6idma at fdt with sun6i_dma
202file	arch/arm/sunxi/sun6i_dma.c		sun6i_dma
203
204# Audio codec
205device	sunxicodec: audiobus, auconv, mulaw, aurateconv
206attach	sunxicodec at fdt with sunxi_codec
207file	arch/arm/sunxi/sunxi_codec.c		sunxi_codec
208file	arch/arm/sunxi/sun4i_a10_codec.c	sunxi_codec
209file	arch/arm/sunxi/sun6i_a31_codec.c	sunxi_codec
210
211# Audio codec (sun8i)
212device	sun8icodec
213attach	sun8icodec at fdt with sun8i_codec
214file	arch/arm/sunxi/sun8i_codec.c		sun8i_codec
215
216# H3 Audio codec (analog part)
217device	h3codec
218attach	h3codec at fdt with h3_codec
219file	arch/arm/sunxi/sun8i_h3_codec.c		h3_codec needs-flag
220
221# A64 Audio codec (analog part)
222device	a64acodec
223attach	a64acodec at fdt with a64_acodec
224file	arch/arm/sunxi/sun50i_a64_acodec.c	a64_acodec
225
226# I2S/PCM controller
227device	sunxii2s: auconv, mulaw, aurateconv
228attach	sunxii2s at fdt with sunxi_i2s
229file	arch/arm/sunxi/sunxi_i2s.c		sunxi_i2s
230
231# Display controller
232attach	genfb at fdt with simplefb
233file	dev/fdt/simplefb.c			simplefb
234
235# A10/A20 LCD/TV timing controller (TCON)
236device	sunxitcon
237attach	sunxitcon at fdt with sunxi_tcon
238file	arch/arm/sunxi/sunxi_tcon.c		sunxi_tcon needs-flag
239
240# A10/A20 Display engine backend (DE-BE)
241device	sunxidebe { }
242attach	sunxidebe at fdt with sunxi_debe
243file	arch/arm/sunxi/sunxi_debe.c		sunxi_debe needs-flag
244
245attach	genfb at sunxidebe with sunxi_befb
246
247# A10/A20 HDMI
248device	sunxihdmi: edid, videomode
249attach	sunxihdmi at fdt with sunxi_hdmi
250file	arch/arm/sunxi/sunxi_hdmi.c		sunxi_hdmi needs-flag
251
252# A10/A20 display engine pipeline
253device sunxidep
254attach	sunxidep at fdt with sunxi_dep
255file	arch/arm/sunxi/sunxi_dep.c		sunxi_dep
256
257# Touch Screen controller
258device	sunxits: wsmousedev, tpcalib, sysmon_envsys
259attach	sunxits at fdt with sunxi_ts
260file	arch/arm/sunxi/sunxi_ts.c		sunxi_ts
261
262# USB OTG
263attach	motg at fdt with sunxi_musb
264file	arch/arm/sunxi/sunxi_musb.c		sunxi_musb
265
266# Security ID EFUSE
267device	sunxisid
268attach	sunxisid at fdt with sunxi_sid
269file	arch/arm/sunxi/sunxi_sid.c		sunxi_sid
270
271# Thermal sensor controller
272device	sunxithermal: sysmon_envsys, sysmon_taskq
273attach	sunxithermal at fdt with sunxi_thermal
274file	arch/arm/sunxi/sunxi_thermal.c		sunxi_thermal
275
276# SATA
277attach	ahcisata at fdt with sunxi_sata
278file	arch/arm/sunxi/sunxi_sata.c		sunxi_sata
279
280# SRAM Controller
281device	sunxisramc
282attach	sunxisramc at fdt with sunxi_sramc
283file	arch/arm/sunxi/sunxi_sramc.c		sunxi_sramc
284
285# NAND Flash Controller
286device	sunxinand: nandbus
287attach	sunxinand at fdt with sunxi_nand
288file	arch/arm/sunxi/sunxi_nand.c		sunxi_nand
289
290# SPI Controller (sun6i-compatible)
291device	sun6ispi: spibus
292attach	sun6ispi at fdt with sun6i_spi
293file	arch/arm/sunxi/sun6i_spi.c		sun6i_spi
294
295# A10/A20 CAN
296device	sunxican { } : ifnet
297attach	sunxican at fdt with sunxi_can
298file	arch/arm/sunxi/sunxi_can.c		sunxi_can
299
300# LRADC
301device	sunxilradc
302attach	sunxilradc at fdt with sunxi_lradc
303file	arch/arm/sunxi/sunxi_lradc.c		sunxi_lradc
304# SOC parameters
305defflag	opt_soc.h			SOC_SUNXI
306defflag	opt_soc.h			SOC_SUN4I: SOC_SUNXI
307defflag	opt_soc.h			SOC_SUN4I_A10: SOC_SUN4I
308defflag	opt_soc.h			SOC_SUN5I: SOC_SUNXI
309defflag	opt_soc.h			SOC_SUN5I_A13: SOC_SUN5I
310defflag	opt_soc.h			SOC_SUN6I: SOC_SUNXI
311defflag	opt_soc.h			SOC_SUN6I_A31: SOC_SUN6I
312defflag	opt_soc.h			SOC_SUN7I: SOC_SUNXI
313defflag	opt_soc.h			SOC_SUN7I_A20: SOC_SUN7I
314defflag	opt_soc.h			SOC_SUN8I: SOC_SUNXI
315defflag	opt_soc.h			SOC_SUN8I_A83T: SOC_SUN8I
316defflag	opt_soc.h			SOC_SUN8I_H3: SOC_SUN8I
317defflag	opt_soc.h			SOC_SUN9I: SOC_SUNXI
318defflag	opt_soc.h			SOC_SUN9I_A80: SOC_SUN9I
319defflag	opt_soc.h			SOC_SUN50I: SOC_SUNXI
320defflag	opt_soc.h			SOC_SUN50I_A64: SOC_SUN50I
321defflag	opt_soc.h			SOC_SUN50I_H5: SOC_SUN50I, SOC_SUN8I_H3
322defflag	opt_soc.h			SOC_SUN50I_H6: SOC_SUN50I
323