Linux Audio

Check our new training course

Loading...
v6.8
 1/* SPDX-License-Identifier: GPL-2.0 */
 2#ifndef B43_BUS_H_
 3#define B43_BUS_H_
 4
 5enum b43_bus_type {
 6#ifdef CONFIG_B43_BCMA
 7	B43_BUS_BCMA,
 8#endif
 9#ifdef CONFIG_B43_SSB
10	B43_BUS_SSB,
11#endif
12};
13
14struct b43_bus_dev {
15	enum b43_bus_type bus_type;
16	union {
17		struct bcma_device *bdev;
18		struct ssb_device *sdev;
19	};
20
21	int (*bus_may_powerdown)(struct b43_bus_dev *dev);
22	int (*bus_powerup)(struct b43_bus_dev *dev, bool dynamic_pctl);
23	int (*device_is_enabled)(struct b43_bus_dev *dev);
24	void (*device_enable)(struct b43_bus_dev *dev,
25			      u32 core_specific_flags);
26	void (*device_disable)(struct b43_bus_dev *dev,
27			       u32 core_specific_flags);
28
29	u16 (*read16)(struct b43_bus_dev *dev, u16 offset);
30	u32 (*read32)(struct b43_bus_dev *dev, u16 offset);
31	void (*write16)(struct b43_bus_dev *dev, u16 offset, u16 value);
32	void (*write32)(struct b43_bus_dev *dev, u16 offset, u32 value);
33	void (*block_read)(struct b43_bus_dev *dev, void *buffer,
34			   size_t count, u16 offset, u8 reg_width);
35	void (*block_write)(struct b43_bus_dev *dev, const void *buffer,
36			    size_t count, u16 offset, u8 reg_width);
37	bool flush_writes;
38
39	struct device *dev;
40	struct device *dma_dev;
41	unsigned int irq;
42
43	u16 board_vendor;
44	u16 board_type;
45	u16 board_rev;
46
47	u16 chip_id;
48	u8 chip_rev;
49	u8 chip_pkg;
50
51	struct ssb_sprom *bus_sprom;
52
53	u16 core_id;
54	u8 core_rev;
55};
56
57static inline bool b43_bus_host_is_pcmcia(struct b43_bus_dev *dev)
58{
59#ifdef CONFIG_B43_SSB
60	return (dev->bus_type == B43_BUS_SSB &&
61		dev->sdev->bus->bustype == SSB_BUSTYPE_PCMCIA);
62#else
63	return false;
64#endif
65};
66
67static inline bool b43_bus_host_is_pci(struct b43_bus_dev *dev)
68{
69#ifdef CONFIG_B43_BCMA
70	if (dev->bus_type == B43_BUS_BCMA)
71		return (dev->bdev->bus->hosttype == BCMA_HOSTTYPE_PCI);
72#endif
73#ifdef CONFIG_B43_SSB
74	if (dev->bus_type == B43_BUS_SSB)
75		return (dev->sdev->bus->bustype == SSB_BUSTYPE_PCI);
76#endif
77	return false;
78}
79
80static inline bool b43_bus_host_is_sdio(struct b43_bus_dev *dev)
81{
82#ifdef CONFIG_B43_SSB
83	return (dev->bus_type == B43_BUS_SSB &&
84		dev->sdev->bus->bustype == SSB_BUSTYPE_SDIO);
85#else
86	return false;
87#endif
88}
89
90struct b43_bus_dev *b43_bus_dev_bcma_init(struct bcma_device *core);
91struct b43_bus_dev *b43_bus_dev_ssb_init(struct ssb_device *sdev);
92
93void *b43_bus_get_wldev(struct b43_bus_dev *dev);
94void b43_bus_set_wldev(struct b43_bus_dev *dev, void *data);
95
96#endif /* B43_BUS_H_ */
v4.6
 
 1#ifndef B43_BUS_H_
 2#define B43_BUS_H_
 3
 4enum b43_bus_type {
 5#ifdef CONFIG_B43_BCMA
 6	B43_BUS_BCMA,
 7#endif
 8#ifdef CONFIG_B43_SSB
 9	B43_BUS_SSB,
10#endif
11};
12
13struct b43_bus_dev {
14	enum b43_bus_type bus_type;
15	union {
16		struct bcma_device *bdev;
17		struct ssb_device *sdev;
18	};
19
20	int (*bus_may_powerdown)(struct b43_bus_dev *dev);
21	int (*bus_powerup)(struct b43_bus_dev *dev, bool dynamic_pctl);
22	int (*device_is_enabled)(struct b43_bus_dev *dev);
23	void (*device_enable)(struct b43_bus_dev *dev,
24			      u32 core_specific_flags);
25	void (*device_disable)(struct b43_bus_dev *dev,
26			       u32 core_specific_flags);
27
28	u16 (*read16)(struct b43_bus_dev *dev, u16 offset);
29	u32 (*read32)(struct b43_bus_dev *dev, u16 offset);
30	void (*write16)(struct b43_bus_dev *dev, u16 offset, u16 value);
31	void (*write32)(struct b43_bus_dev *dev, u16 offset, u32 value);
32	void (*block_read)(struct b43_bus_dev *dev, void *buffer,
33			   size_t count, u16 offset, u8 reg_width);
34	void (*block_write)(struct b43_bus_dev *dev, const void *buffer,
35			    size_t count, u16 offset, u8 reg_width);
36	bool flush_writes;
37
38	struct device *dev;
39	struct device *dma_dev;
40	unsigned int irq;
41
42	u16 board_vendor;
43	u16 board_type;
44	u16 board_rev;
45
46	u16 chip_id;
47	u8 chip_rev;
48	u8 chip_pkg;
49
50	struct ssb_sprom *bus_sprom;
51
52	u16 core_id;
53	u8 core_rev;
54};
55
56static inline bool b43_bus_host_is_pcmcia(struct b43_bus_dev *dev)
57{
58#ifdef CONFIG_B43_SSB
59	return (dev->bus_type == B43_BUS_SSB &&
60		dev->sdev->bus->bustype == SSB_BUSTYPE_PCMCIA);
61#else
62	return false;
63#endif
64};
65
66static inline bool b43_bus_host_is_pci(struct b43_bus_dev *dev)
67{
68#ifdef CONFIG_B43_BCMA
69	if (dev->bus_type == B43_BUS_BCMA)
70		return (dev->bdev->bus->hosttype == BCMA_HOSTTYPE_PCI);
71#endif
72#ifdef CONFIG_B43_SSB
73	if (dev->bus_type == B43_BUS_SSB)
74		return (dev->sdev->bus->bustype == SSB_BUSTYPE_PCI);
75#endif
76	return false;
77}
78
79static inline bool b43_bus_host_is_sdio(struct b43_bus_dev *dev)
80{
81#ifdef CONFIG_B43_SSB
82	return (dev->bus_type == B43_BUS_SSB &&
83		dev->sdev->bus->bustype == SSB_BUSTYPE_SDIO);
84#else
85	return false;
86#endif
87}
88
89struct b43_bus_dev *b43_bus_dev_bcma_init(struct bcma_device *core);
90struct b43_bus_dev *b43_bus_dev_ssb_init(struct ssb_device *sdev);
91
92void *b43_bus_get_wldev(struct b43_bus_dev *dev);
93void b43_bus_set_wldev(struct b43_bus_dev *dev, void *data);
94
95#endif /* B43_BUS_H_ */