| /* SPDX-License-Identifier: GPL-2.0 */ |
| #ifndef B43_BUS_H_ |
| #define B43_BUS_H_ |
| |
| enum b43_bus_type { |
| #ifdef CONFIG_B43_BCMA |
| B43_BUS_BCMA, |
| #endif |
| #ifdef CONFIG_B43_SSB |
| B43_BUS_SSB, |
| #endif |
| }; |
| |
| struct b43_bus_dev { |
| enum b43_bus_type bus_type; |
| union { |
| struct bcma_device *bdev; |
| struct ssb_device *sdev; |
| }; |
| |
| int (*bus_may_powerdown)(struct b43_bus_dev *dev); |
| int (*bus_powerup)(struct b43_bus_dev *dev, bool dynamic_pctl); |
| int (*device_is_enabled)(struct b43_bus_dev *dev); |
| void (*device_enable)(struct b43_bus_dev *dev, |
| u32 core_specific_flags); |
| void (*device_disable)(struct b43_bus_dev *dev, |
| u32 core_specific_flags); |
| |
| u16 (*read16)(struct b43_bus_dev *dev, u16 offset); |
| u32 (*read32)(struct b43_bus_dev *dev, u16 offset); |
| void (*write16)(struct b43_bus_dev *dev, u16 offset, u16 value); |
| void (*write32)(struct b43_bus_dev *dev, u16 offset, u32 value); |
| void (*block_read)(struct b43_bus_dev *dev, void *buffer, |
| size_t count, u16 offset, u8 reg_width); |
| void (*block_write)(struct b43_bus_dev *dev, const void *buffer, |
| size_t count, u16 offset, u8 reg_width); |
| bool flush_writes; |
| |
| struct device *dev; |
| struct device *dma_dev; |
| unsigned int irq; |
| |
| u16 board_vendor; |
| u16 board_type; |
| u16 board_rev; |
| |
| u16 chip_id; |
| u8 chip_rev; |
| u8 chip_pkg; |
| |
| struct ssb_sprom *bus_sprom; |
| |
| u16 core_id; |
| u8 core_rev; |
| }; |
| |
| static inline bool b43_bus_host_is_pcmcia(struct b43_bus_dev *dev) |
| { |
| #ifdef CONFIG_B43_SSB |
| return (dev->bus_type == B43_BUS_SSB && |
| dev->sdev->bus->bustype == SSB_BUSTYPE_PCMCIA); |
| #else |
| return false; |
| #endif |
| }; |
| |
| static inline bool b43_bus_host_is_pci(struct b43_bus_dev *dev) |
| { |
| #ifdef CONFIG_B43_BCMA |
| if (dev->bus_type == B43_BUS_BCMA) |
| return (dev->bdev->bus->hosttype == BCMA_HOSTTYPE_PCI); |
| #endif |
| #ifdef CONFIG_B43_SSB |
| if (dev->bus_type == B43_BUS_SSB) |
| return (dev->sdev->bus->bustype == SSB_BUSTYPE_PCI); |
| #endif |
| return false; |
| } |
| |
| static inline bool b43_bus_host_is_sdio(struct b43_bus_dev *dev) |
| { |
| #ifdef CONFIG_B43_SSB |
| return (dev->bus_type == B43_BUS_SSB && |
| dev->sdev->bus->bustype == SSB_BUSTYPE_SDIO); |
| #else |
| return false; |
| #endif |
| } |
| |
| struct b43_bus_dev *b43_bus_dev_bcma_init(struct bcma_device *core); |
| struct b43_bus_dev *b43_bus_dev_ssb_init(struct ssb_device *sdev); |
| |
| void *b43_bus_get_wldev(struct b43_bus_dev *dev); |
| void b43_bus_set_wldev(struct b43_bus_dev *dev, void *data); |
| |
| #endif /* B43_BUS_H_ */ |