blob: fd88e2b121a043a306be9c413e14d1220ed85ed5 [file] [log] [blame]
Rafał Miłecki482f0532011-05-18 02:06:36 +02001#ifndef B43_BUS_H_
2#define B43_BUS_H_
3
4enum b43_bus_type {
5 B43_BUS_SSB,
6};
7
8struct b43_bus_dev {
9 enum b43_bus_type bus_type;
10 union {
11 struct ssb_device *sdev;
12 };
Rafał Miłeckic0b4c002011-05-18 02:06:37 +020013
Rafał Miłecki24ca39d2011-05-18 02:06:43 +020014 int (*bus_may_powerdown)(struct b43_bus_dev *dev);
15 int (*bus_powerup)(struct b43_bus_dev *dev, bool dynamic_pctl);
16 int (*device_is_enabled)(struct b43_bus_dev *dev);
17 void (*device_enable)(struct b43_bus_dev *dev,
18 u32 core_specific_flags);
19 void (*device_disable)(struct b43_bus_dev *dev,
20 u32 core_specific_flags);
21
Rafał Miłeckic0b4c002011-05-18 02:06:37 +020022 u16 (*read16)(struct b43_bus_dev *dev, u16 offset);
23 u32 (*read32)(struct b43_bus_dev *dev, u16 offset);
24 void (*write16)(struct b43_bus_dev *dev, u16 offset, u16 value);
25 void (*write32)(struct b43_bus_dev *dev, u16 offset, u32 value);
26 void (*block_read)(struct b43_bus_dev *dev, void *buffer,
27 size_t count, u16 offset, u8 reg_width);
28 void (*block_write)(struct b43_bus_dev *dev, const void *buffer,
29 size_t count, u16 offset, u8 reg_width);
Rafał Miłecki21d889d2011-05-18 02:06:38 +020030
Rafał Miłeckia18c7152011-05-18 02:06:40 +020031 struct device *dev;
32 struct device *dma_dev;
33 unsigned int irq;
34
Rafał Miłecki79d22322011-05-18 02:06:42 +020035 u16 board_vendor;
36 u16 board_type;
37 u16 board_rev;
38
Rafał Miłeckic244e082011-05-18 02:06:41 +020039 u16 chip_id;
40 u8 chip_rev;
41 u8 chip_pkg;
42
Rafał Miłecki05814832011-05-18 02:06:39 +020043 struct ssb_sprom *bus_sprom;
44
Rafał Miłecki21d889d2011-05-18 02:06:38 +020045 u16 core_id;
46 u8 core_rev;
Rafał Miłecki482f0532011-05-18 02:06:36 +020047};
48
49struct b43_bus_dev *b43_bus_dev_ssb_init(struct ssb_device *sdev);
50
51#endif /* B43_BUS_H_ */