diff options
Diffstat (limited to 'include/linux/platform_data/ti-sysc.h')
-rw-r--r-- | include/linux/platform_data/ti-sysc.h | 86 |
1 files changed, 86 insertions, 0 deletions
diff --git a/include/linux/platform_data/ti-sysc.h b/include/linux/platform_data/ti-sysc.h new file mode 100644 index 000000000000..1be356330b96 --- /dev/null +++ b/include/linux/platform_data/ti-sysc.h | |||
@@ -0,0 +1,86 @@ | |||
1 | #ifndef __TI_SYSC_DATA_H__ | ||
2 | #define __TI_SYSC_DATA_H__ | ||
3 | |||
4 | enum ti_sysc_module_type { | ||
5 | TI_SYSC_OMAP2, | ||
6 | TI_SYSC_OMAP2_TIMER, | ||
7 | TI_SYSC_OMAP3_SHAM, | ||
8 | TI_SYSC_OMAP3_AES, | ||
9 | TI_SYSC_OMAP4, | ||
10 | TI_SYSC_OMAP4_TIMER, | ||
11 | TI_SYSC_OMAP4_SIMPLE, | ||
12 | TI_SYSC_OMAP34XX_SR, | ||
13 | TI_SYSC_OMAP36XX_SR, | ||
14 | TI_SYSC_OMAP4_SR, | ||
15 | TI_SYSC_OMAP4_MCASP, | ||
16 | TI_SYSC_OMAP4_USB_HOST_FS, | ||
17 | }; | ||
18 | |||
19 | /** | ||
20 | * struct sysc_regbits - TI OCP_SYSCONFIG register field offsets | ||
21 | * @midle_shift: Offset of the midle bit | ||
22 | * @clkact_shift: Offset of the clockactivity bit | ||
23 | * @sidle_shift: Offset of the sidle bit | ||
24 | * @enwkup_shift: Offset of the enawakeup bit | ||
25 | * @srst_shift: Offset of the softreset bit | ||
26 | * @autoidle_shift: Offset of the autoidle bit | ||
27 | * @dmadisable_shift: Offset of the dmadisable bit | ||
28 | * @emufree_shift; Offset of the emufree bit | ||
29 | * | ||
30 | * Note that 0 is a valid shift, and for ti-sysc.c -ENODEV can be used if a | ||
31 | * feature is not available. | ||
32 | */ | ||
33 | struct sysc_regbits { | ||
34 | s8 midle_shift; | ||
35 | s8 clkact_shift; | ||
36 | s8 sidle_shift; | ||
37 | s8 enwkup_shift; | ||
38 | s8 srst_shift; | ||
39 | s8 autoidle_shift; | ||
40 | s8 dmadisable_shift; | ||
41 | s8 emufree_shift; | ||
42 | }; | ||
43 | |||
44 | #define SYSC_QUIRK_RESET_STATUS BIT(7) | ||
45 | #define SYSC_QUIRK_NO_IDLE_ON_INIT BIT(6) | ||
46 | #define SYSC_QUIRK_NO_RESET_ON_INIT BIT(5) | ||
47 | #define SYSC_QUIRK_OPT_CLKS_NEEDED BIT(4) | ||
48 | #define SYSC_QUIRK_OPT_CLKS_IN_RESET BIT(3) | ||
49 | #define SYSC_QUIRK_16BIT BIT(2) | ||
50 | #define SYSC_QUIRK_UNCACHED BIT(1) | ||
51 | #define SYSC_QUIRK_USE_CLOCKACT BIT(0) | ||
52 | |||
53 | #define SYSC_NR_IDLEMODES 4 | ||
54 | |||
55 | /** | ||
56 | * struct sysc_capabilities - capabilities for an interconnect target module | ||
57 | * | ||
58 | * @sysc_mask: bitmask of supported SYSCONFIG register bits | ||
59 | * @regbits: bitmask of SYSCONFIG register bits | ||
60 | * @mod_quirks: bitmask of module specific quirks | ||
61 | */ | ||
62 | struct sysc_capabilities { | ||
63 | const enum ti_sysc_module_type type; | ||
64 | const u32 sysc_mask; | ||
65 | const struct sysc_regbits *regbits; | ||
66 | const u32 mod_quirks; | ||
67 | }; | ||
68 | |||
69 | /** | ||
70 | * struct sysc_config - configuration for an interconnect target module | ||
71 | * @sysc_val: configured value for sysc register | ||
72 | * @midlemodes: bitmask of supported master idle modes | ||
73 | * @sidlemodes: bitmask of supported master idle modes | ||
74 | * @srst_udelay: optional delay needed after OCP soft reset | ||
75 | * @quirks: bitmask of enabled quirks | ||
76 | */ | ||
77 | struct sysc_config { | ||
78 | u32 sysc_val; | ||
79 | u32 syss_mask; | ||
80 | u8 midlemodes; | ||
81 | u8 sidlemodes; | ||
82 | u8 srst_udelay; | ||
83 | u32 quirks; | ||
84 | }; | ||
85 | |||
86 | #endif /* __TI_SYSC_DATA_H__ */ | ||