blob: 184c95659279070f2a64edfa6628f109ded51f22 [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 {
Rafał Miłecki6cbab0d2011-07-06 15:45:26 +02005#ifdef CONFIG_B43_BCMA
Rafał Miłecki397915c2011-07-06 19:03:46 +02006 B43_BUS_BCMA,
Rafał Miłecki6cbab0d2011-07-06 15:45:26 +02007#endif
Rafał Miłecki482f0532011-05-18 02:06:36 +02008 B43_BUS_SSB,
9};
10
11struct b43_bus_dev {
12 enum b43_bus_type bus_type;
13 union {
Rafał Miłecki397915c2011-07-06 19:03:46 +020014 struct bcma_device *bdev;
Rafał Miłecki482f0532011-05-18 02:06:36 +020015 struct ssb_device *sdev;
16 };
Rafał Miłeckic0b4c002011-05-18 02:06:37 +020017
Rafał Miłecki24ca39d2011-05-18 02:06:43 +020018 int (*bus_may_powerdown)(struct b43_bus_dev *dev);
19 int (*bus_powerup)(struct b43_bus_dev *dev, bool dynamic_pctl);
20 int (*device_is_enabled)(struct b43_bus_dev *dev);
21 void (*device_enable)(struct b43_bus_dev *dev,
22 u32 core_specific_flags);
23 void (*device_disable)(struct b43_bus_dev *dev,
24 u32 core_specific_flags);
25
Rafał Miłeckic0b4c002011-05-18 02:06:37 +020026 u16 (*read16)(struct b43_bus_dev *dev, u16 offset);
27 u32 (*read32)(struct b43_bus_dev *dev, u16 offset);
28 void (*write16)(struct b43_bus_dev *dev, u16 offset, u16 value);
29 void (*write32)(struct b43_bus_dev *dev, u16 offset, u32 value);
30 void (*block_read)(struct b43_bus_dev *dev, void *buffer,
31 size_t count, u16 offset, u8 reg_width);
32 void (*block_write)(struct b43_bus_dev *dev, const void *buffer,
33 size_t count, u16 offset, u8 reg_width);
Rafał Miłecki21d889d2011-05-18 02:06:38 +020034
Rafał Miłeckia18c7152011-05-18 02:06:40 +020035 struct device *dev;
36 struct device *dma_dev;
37 unsigned int irq;
38
Rafał Miłecki79d22322011-05-18 02:06:42 +020039 u16 board_vendor;
40 u16 board_type;
41 u16 board_rev;
42
Rafał Miłeckic244e082011-05-18 02:06:41 +020043 u16 chip_id;
44 u8 chip_rev;
45 u8 chip_pkg;
46
Rafał Miłecki05814832011-05-18 02:06:39 +020047 struct ssb_sprom *bus_sprom;
48
Rafał Miłecki21d889d2011-05-18 02:06:38 +020049 u16 core_id;
50 u8 core_rev;
Rafał Miłecki482f0532011-05-18 02:06:36 +020051};
52
Rafał Miłecki505fb012011-05-19 15:11:27 +020053static inline bool b43_bus_host_is_pcmcia(struct b43_bus_dev *dev)
54{
55 return (dev->bus_type == B43_BUS_SSB &&
56 dev->sdev->bus->bustype == SSB_BUSTYPE_PCMCIA);
57}
58static inline bool b43_bus_host_is_sdio(struct b43_bus_dev *dev)
59{
60 return (dev->bus_type == B43_BUS_SSB &&
61 dev->sdev->bus->bustype == SSB_BUSTYPE_SDIO);
62}
63
Rafał Miłecki397915c2011-07-06 19:03:46 +020064struct b43_bus_dev *b43_bus_dev_bcma_init(struct bcma_device *core);
Rafał Miłecki482f0532011-05-18 02:06:36 +020065struct b43_bus_dev *b43_bus_dev_ssb_init(struct ssb_device *sdev);
66
Rafał Miłecki74abacb2011-07-06 15:45:28 +020067void *b43_bus_get_wldev(struct b43_bus_dev *dev);
68void b43_bus_set_wldev(struct b43_bus_dev *dev, void *data);
69
Rafał Miłecki482f0532011-05-18 02:06:36 +020070#endif /* B43_BUS_H_ */