1
2
3
4
5
6
7 #ifndef __PMAC_LOW_I2C_H__
8 #define __PMAC_LOW_I2C_H__
9 #ifdef __KERNEL__
10
11
12 enum {
13 pmac_i2c_mode_dumb = 1,
14 pmac_i2c_mode_std = 2,
15 pmac_i2c_mode_stdsub = 3,
16 pmac_i2c_mode_combined = 4,
17 };
18
19
20 enum {
21 pmac_i2c_read = 0x01,
22 pmac_i2c_write = 0x00
23 };
24
25
26 enum {
27 pmac_i2c_bus_keywest = 0,
28 pmac_i2c_bus_pmu = 1,
29 pmac_i2c_bus_smu = 2,
30 };
31
32
33 enum {
34
35 pmac_i2c_can_largesub = 0x00000001u,
36
37
38
39
40 pmac_i2c_multibus = 0x00000002u,
41 };
42
43
44 struct pmac_i2c_bus;
45 struct i2c_adapter;
46
47
48 extern int pmac_i2c_init(void);
49
50
51
52
53
54
55 extern struct pmac_i2c_bus *pmac_i2c_find_bus(struct device_node *node);
56
57
58
59
60
61 extern u8 pmac_i2c_get_dev_addr(struct device_node *device);
62
63
64 extern struct device_node *pmac_i2c_get_controller(struct pmac_i2c_bus *bus);
65 extern struct device_node *pmac_i2c_get_bus_node(struct pmac_i2c_bus *bus);
66 extern int pmac_i2c_get_type(struct pmac_i2c_bus *bus);
67 extern int pmac_i2c_get_flags(struct pmac_i2c_bus *bus);
68 extern int pmac_i2c_get_channel(struct pmac_i2c_bus *bus);
69
70
71 extern struct i2c_adapter *pmac_i2c_get_adapter(struct pmac_i2c_bus *bus);
72 extern struct pmac_i2c_bus *pmac_i2c_adapter_to_bus(struct i2c_adapter *adapter);
73
74
75
76
77
78 extern int pmac_i2c_match_adapter(struct device_node *dev,
79 struct i2c_adapter *adapter);
80
81
82
83 extern int pmac_low_i2c_lock(struct device_node *np);
84 extern int pmac_low_i2c_unlock(struct device_node *np);
85
86
87 extern int pmac_i2c_open(struct pmac_i2c_bus *bus, int polled);
88 extern void pmac_i2c_close(struct pmac_i2c_bus *bus);
89 extern int pmac_i2c_setmode(struct pmac_i2c_bus *bus, int mode);
90 extern int pmac_i2c_xfer(struct pmac_i2c_bus *bus, u8 addrdir, int subsize,
91 u32 subaddr, u8 *data, int len);
92
93
94 extern void pmac_pfunc_i2c_suspend(void);
95 extern void pmac_pfunc_i2c_resume(void);
96
97 #endif
98 #endif