| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 1 | #ifndef LINUX_BCMA_H_ | 
|  | 2 | #define LINUX_BCMA_H_ | 
|  | 3 |  | 
|  | 4 | #include <linux/pci.h> | 
|  | 5 | #include <linux/mod_devicetable.h> | 
|  | 6 |  | 
|  | 7 | #include <linux/bcma/bcma_driver_chipcommon.h> | 
|  | 8 | #include <linux/bcma/bcma_driver_pci.h> | 
| Hauke Mehrtens | 21e0534 | 2011-07-23 01:20:09 +0200 | [diff] [blame] | 9 | #include <linux/bcma/bcma_driver_mips.h> | 
| Rafał Miłecki | 27f18dc | 2011-06-02 02:08:51 +0200 | [diff] [blame] | 10 | #include <linux/ssb/ssb.h> /* SPROM sharing */ | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 11 |  | 
|  | 12 | #include "bcma_regs.h" | 
|  | 13 |  | 
|  | 14 | struct bcma_device; | 
|  | 15 | struct bcma_bus; | 
|  | 16 |  | 
|  | 17 | enum bcma_hosttype { | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 18 | BCMA_HOSTTYPE_PCI, | 
|  | 19 | BCMA_HOSTTYPE_SDIO, | 
| Hauke Mehrtens | ecd177c | 2011-07-23 01:20:08 +0200 | [diff] [blame] | 20 | BCMA_HOSTTYPE_SOC, | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 21 | }; | 
|  | 22 |  | 
|  | 23 | struct bcma_chipinfo { | 
|  | 24 | u16 id; | 
|  | 25 | u8 rev; | 
|  | 26 | u8 pkg; | 
|  | 27 | }; | 
|  | 28 |  | 
| Hauke Mehrtens | 0a2fcaa | 2012-04-29 02:04:08 +0200 | [diff] [blame^] | 29 | struct bcma_boardinfo { | 
|  | 30 | u16 vendor; | 
|  | 31 | u16 type; | 
|  | 32 | }; | 
|  | 33 |  | 
| Rafał Miłecki | 7424dd0 | 2011-07-17 01:06:04 +0200 | [diff] [blame] | 34 | enum bcma_clkmode { | 
|  | 35 | BCMA_CLKMODE_FAST, | 
|  | 36 | BCMA_CLKMODE_DYNAMIC, | 
|  | 37 | }; | 
|  | 38 |  | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 39 | struct bcma_host_ops { | 
|  | 40 | u8 (*read8)(struct bcma_device *core, u16 offset); | 
|  | 41 | u16 (*read16)(struct bcma_device *core, u16 offset); | 
|  | 42 | u32 (*read32)(struct bcma_device *core, u16 offset); | 
|  | 43 | void (*write8)(struct bcma_device *core, u16 offset, u8 value); | 
|  | 44 | void (*write16)(struct bcma_device *core, u16 offset, u16 value); | 
|  | 45 | void (*write32)(struct bcma_device *core, u16 offset, u32 value); | 
| Rafał Miłecki | 9d75ef0 | 2011-05-20 03:27:06 +0200 | [diff] [blame] | 46 | #ifdef CONFIG_BCMA_BLOCKIO | 
|  | 47 | void (*block_read)(struct bcma_device *core, void *buffer, | 
|  | 48 | size_t count, u16 offset, u8 reg_width); | 
|  | 49 | void (*block_write)(struct bcma_device *core, const void *buffer, | 
|  | 50 | size_t count, u16 offset, u8 reg_width); | 
|  | 51 | #endif | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 52 | /* Agent ops */ | 
|  | 53 | u32 (*aread32)(struct bcma_device *core, u16 offset); | 
|  | 54 | void (*awrite32)(struct bcma_device *core, u16 offset, u32 value); | 
|  | 55 | }; | 
|  | 56 |  | 
|  | 57 | /* Core manufacturers */ | 
|  | 58 | #define BCMA_MANUF_ARM			0x43B | 
|  | 59 | #define BCMA_MANUF_MIPS			0x4A7 | 
|  | 60 | #define BCMA_MANUF_BCM			0x4BF | 
|  | 61 |  | 
|  | 62 | /* Core class values. */ | 
|  | 63 | #define BCMA_CL_SIM			0x0 | 
|  | 64 | #define BCMA_CL_EROM			0x1 | 
|  | 65 | #define BCMA_CL_CORESIGHT		0x9 | 
|  | 66 | #define BCMA_CL_VERIF			0xB | 
|  | 67 | #define BCMA_CL_OPTIMO			0xD | 
|  | 68 | #define BCMA_CL_GEN			0xE | 
|  | 69 | #define BCMA_CL_PRIMECELL		0xF | 
|  | 70 |  | 
|  | 71 | /* Core-ID values. */ | 
|  | 72 | #define BCMA_CORE_OOB_ROUTER		0x367	/* Out of band */ | 
|  | 73 | #define BCMA_CORE_INVALID		0x700 | 
|  | 74 | #define BCMA_CORE_CHIPCOMMON		0x800 | 
|  | 75 | #define BCMA_CORE_ILINE20		0x801 | 
|  | 76 | #define BCMA_CORE_SRAM			0x802 | 
|  | 77 | #define BCMA_CORE_SDRAM			0x803 | 
|  | 78 | #define BCMA_CORE_PCI			0x804 | 
|  | 79 | #define BCMA_CORE_MIPS			0x805 | 
|  | 80 | #define BCMA_CORE_ETHERNET		0x806 | 
|  | 81 | #define BCMA_CORE_V90			0x807 | 
|  | 82 | #define BCMA_CORE_USB11_HOSTDEV		0x808 | 
|  | 83 | #define BCMA_CORE_ADSL			0x809 | 
|  | 84 | #define BCMA_CORE_ILINE100		0x80A | 
|  | 85 | #define BCMA_CORE_IPSEC			0x80B | 
|  | 86 | #define BCMA_CORE_UTOPIA		0x80C | 
|  | 87 | #define BCMA_CORE_PCMCIA		0x80D | 
|  | 88 | #define BCMA_CORE_INTERNAL_MEM		0x80E | 
|  | 89 | #define BCMA_CORE_MEMC_SDRAM		0x80F | 
|  | 90 | #define BCMA_CORE_OFDM			0x810 | 
|  | 91 | #define BCMA_CORE_EXTIF			0x811 | 
|  | 92 | #define BCMA_CORE_80211			0x812 | 
|  | 93 | #define BCMA_CORE_PHY_A			0x813 | 
|  | 94 | #define BCMA_CORE_PHY_B			0x814 | 
|  | 95 | #define BCMA_CORE_PHY_G			0x815 | 
|  | 96 | #define BCMA_CORE_MIPS_3302		0x816 | 
|  | 97 | #define BCMA_CORE_USB11_HOST		0x817 | 
|  | 98 | #define BCMA_CORE_USB11_DEV		0x818 | 
|  | 99 | #define BCMA_CORE_USB20_HOST		0x819 | 
|  | 100 | #define BCMA_CORE_USB20_DEV		0x81A | 
|  | 101 | #define BCMA_CORE_SDIO_HOST		0x81B | 
|  | 102 | #define BCMA_CORE_ROBOSWITCH		0x81C | 
|  | 103 | #define BCMA_CORE_PARA_ATA		0x81D | 
|  | 104 | #define BCMA_CORE_SATA_XORDMA		0x81E | 
|  | 105 | #define BCMA_CORE_ETHERNET_GBIT		0x81F | 
|  | 106 | #define BCMA_CORE_PCIE			0x820 | 
|  | 107 | #define BCMA_CORE_PHY_N			0x821 | 
|  | 108 | #define BCMA_CORE_SRAM_CTL		0x822 | 
|  | 109 | #define BCMA_CORE_MINI_MACPHY		0x823 | 
|  | 110 | #define BCMA_CORE_ARM_1176		0x824 | 
|  | 111 | #define BCMA_CORE_ARM_7TDMI		0x825 | 
|  | 112 | #define BCMA_CORE_PHY_LP		0x826 | 
|  | 113 | #define BCMA_CORE_PMU			0x827 | 
|  | 114 | #define BCMA_CORE_PHY_SSN		0x828 | 
|  | 115 | #define BCMA_CORE_SDIO_DEV		0x829 | 
|  | 116 | #define BCMA_CORE_ARM_CM3		0x82A | 
|  | 117 | #define BCMA_CORE_PHY_HT		0x82B | 
|  | 118 | #define BCMA_CORE_MIPS_74K		0x82C | 
|  | 119 | #define BCMA_CORE_MAC_GBIT		0x82D | 
|  | 120 | #define BCMA_CORE_DDR12_MEM_CTL		0x82E | 
|  | 121 | #define BCMA_CORE_PCIE_RC		0x82F	/* PCIe Root Complex */ | 
|  | 122 | #define BCMA_CORE_OCP_OCP_BRIDGE	0x830 | 
|  | 123 | #define BCMA_CORE_SHARED_COMMON		0x831 | 
|  | 124 | #define BCMA_CORE_OCP_AHB_BRIDGE	0x832 | 
|  | 125 | #define BCMA_CORE_SPI_HOST		0x833 | 
|  | 126 | #define BCMA_CORE_I2S			0x834 | 
|  | 127 | #define BCMA_CORE_SDR_DDR1_MEM_CTL	0x835	/* SDR/DDR1 memory controller core */ | 
|  | 128 | #define BCMA_CORE_SHIM			0x837	/* SHIM component in ubus/6362 */ | 
|  | 129 | #define BCMA_CORE_DEFAULT		0xFFF | 
|  | 130 |  | 
|  | 131 | #define BCMA_MAX_NR_CORES		16 | 
|  | 132 |  | 
|  | 133 | struct bcma_device { | 
|  | 134 | struct bcma_bus *bus; | 
|  | 135 | struct bcma_device_id id; | 
|  | 136 |  | 
|  | 137 | struct device dev; | 
| Rafał Miłecki | 1bdcd09 | 2011-05-18 11:40:22 +0200 | [diff] [blame] | 138 | struct device *dma_dev; | 
| Hauke Mehrtens | 21e0534 | 2011-07-23 01:20:09 +0200 | [diff] [blame] | 139 |  | 
| Rafał Miłecki | 1bdcd09 | 2011-05-18 11:40:22 +0200 | [diff] [blame] | 140 | unsigned int irq; | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 141 | bool dev_registered; | 
|  | 142 |  | 
|  | 143 | u8 core_index; | 
| Hauke Mehrtens | 5f2d617 | 2012-01-31 00:03:31 +0100 | [diff] [blame] | 144 | u8 core_unit; | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 145 |  | 
|  | 146 | u32 addr; | 
|  | 147 | u32 wrap; | 
|  | 148 |  | 
| Hauke Mehrtens | ecd177c | 2011-07-23 01:20:08 +0200 | [diff] [blame] | 149 | void __iomem *io_addr; | 
|  | 150 | void __iomem *io_wrap; | 
|  | 151 |  | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 152 | void *drvdata; | 
|  | 153 | struct list_head list; | 
|  | 154 | }; | 
|  | 155 |  | 
|  | 156 | static inline void *bcma_get_drvdata(struct bcma_device *core) | 
|  | 157 | { | 
|  | 158 | return core->drvdata; | 
|  | 159 | } | 
|  | 160 | static inline void bcma_set_drvdata(struct bcma_device *core, void *drvdata) | 
|  | 161 | { | 
|  | 162 | core->drvdata = drvdata; | 
|  | 163 | } | 
|  | 164 |  | 
|  | 165 | struct bcma_driver { | 
|  | 166 | const char *name; | 
|  | 167 | const struct bcma_device_id *id_table; | 
|  | 168 |  | 
|  | 169 | int (*probe)(struct bcma_device *dev); | 
|  | 170 | void (*remove)(struct bcma_device *dev); | 
| Linus Torvalds | 7d5869e | 2012-01-13 23:58:41 +0100 | [diff] [blame] | 171 | int (*suspend)(struct bcma_device *dev); | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 172 | int (*resume)(struct bcma_device *dev); | 
|  | 173 | void (*shutdown)(struct bcma_device *dev); | 
|  | 174 |  | 
|  | 175 | struct device_driver drv; | 
|  | 176 | }; | 
|  | 177 | extern | 
|  | 178 | int __bcma_driver_register(struct bcma_driver *drv, struct module *owner); | 
| Paul Gortmaker | eb5589a | 2011-05-27 09:02:11 -0400 | [diff] [blame] | 179 | #define bcma_driver_register(drv) \ | 
|  | 180 | __bcma_driver_register(drv, THIS_MODULE) | 
|  | 181 |  | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 182 | extern void bcma_driver_unregister(struct bcma_driver *drv); | 
|  | 183 |  | 
| Hauke Mehrtens | a027237 | 2012-02-28 00:56:10 +0100 | [diff] [blame] | 184 | /* Set a fallback SPROM. | 
|  | 185 | * See kdoc at the function definition for complete documentation. */ | 
|  | 186 | extern int bcma_arch_register_fallback_sprom( | 
|  | 187 | int (*sprom_callback)(struct bcma_bus *bus, | 
|  | 188 | struct ssb_sprom *out)); | 
|  | 189 |  | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 190 | struct bcma_bus { | 
|  | 191 | /* The MMIO area. */ | 
|  | 192 | void __iomem *mmio; | 
|  | 193 |  | 
|  | 194 | const struct bcma_host_ops *ops; | 
|  | 195 |  | 
|  | 196 | enum bcma_hosttype hosttype; | 
|  | 197 | union { | 
|  | 198 | /* Pointer to the PCI bus (only for BCMA_HOSTTYPE_PCI) */ | 
|  | 199 | struct pci_dev *host_pci; | 
|  | 200 | /* Pointer to the SDIO device (only for BCMA_HOSTTYPE_SDIO) */ | 
|  | 201 | struct sdio_func *host_sdio; | 
|  | 202 | }; | 
|  | 203 |  | 
|  | 204 | struct bcma_chipinfo chipinfo; | 
|  | 205 |  | 
| Hauke Mehrtens | 0a2fcaa | 2012-04-29 02:04:08 +0200 | [diff] [blame^] | 206 | struct bcma_boardinfo boardinfo; | 
|  | 207 |  | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 208 | struct bcma_device *mapped_core; | 
|  | 209 | struct list_head cores; | 
|  | 210 | u8 nr_cores; | 
| Hauke Mehrtens | 517f43e | 2011-07-23 01:20:07 +0200 | [diff] [blame] | 211 | u8 init_done:1; | 
| Hauke Mehrtens | 8f9ada4 | 2012-01-31 00:03:36 +0100 | [diff] [blame] | 212 | u8 num; | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 213 |  | 
|  | 214 | struct bcma_drv_cc drv_cc; | 
|  | 215 | struct bcma_drv_pci drv_pci; | 
| Hauke Mehrtens | 21e0534 | 2011-07-23 01:20:09 +0200 | [diff] [blame] | 216 | struct bcma_drv_mips drv_mips; | 
| Rafał Miłecki | 27f18dc | 2011-06-02 02:08:51 +0200 | [diff] [blame] | 217 |  | 
|  | 218 | /* We decided to share SPROM struct with SSB as long as we do not need | 
|  | 219 | * any hacks for BCMA. This simplifies drivers code. */ | 
|  | 220 | struct ssb_sprom sprom; | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 221 | }; | 
|  | 222 |  | 
| Arend van Spriel | 0844555 | 2011-12-08 15:06:42 -0800 | [diff] [blame] | 223 | static inline u32 bcma_read8(struct bcma_device *core, u16 offset) | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 224 | { | 
|  | 225 | return core->bus->ops->read8(core, offset); | 
|  | 226 | } | 
| Arend van Spriel | 0844555 | 2011-12-08 15:06:42 -0800 | [diff] [blame] | 227 | static inline u32 bcma_read16(struct bcma_device *core, u16 offset) | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 228 | { | 
|  | 229 | return core->bus->ops->read16(core, offset); | 
|  | 230 | } | 
| Arend van Spriel | 0844555 | 2011-12-08 15:06:42 -0800 | [diff] [blame] | 231 | static inline u32 bcma_read32(struct bcma_device *core, u16 offset) | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 232 | { | 
|  | 233 | return core->bus->ops->read32(core, offset); | 
|  | 234 | } | 
| Arend van Spriel | 0844555 | 2011-12-08 15:06:42 -0800 | [diff] [blame] | 235 | static inline | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 236 | void bcma_write8(struct bcma_device *core, u16 offset, u32 value) | 
|  | 237 | { | 
|  | 238 | core->bus->ops->write8(core, offset, value); | 
|  | 239 | } | 
| Arend van Spriel | 0844555 | 2011-12-08 15:06:42 -0800 | [diff] [blame] | 240 | static inline | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 241 | void bcma_write16(struct bcma_device *core, u16 offset, u32 value) | 
|  | 242 | { | 
|  | 243 | core->bus->ops->write16(core, offset, value); | 
|  | 244 | } | 
| Arend van Spriel | 0844555 | 2011-12-08 15:06:42 -0800 | [diff] [blame] | 245 | static inline | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 246 | void bcma_write32(struct bcma_device *core, u16 offset, u32 value) | 
|  | 247 | { | 
|  | 248 | core->bus->ops->write32(core, offset, value); | 
|  | 249 | } | 
| Rafał Miłecki | 9d75ef0 | 2011-05-20 03:27:06 +0200 | [diff] [blame] | 250 | #ifdef CONFIG_BCMA_BLOCKIO | 
| Arend van Spriel | 0844555 | 2011-12-08 15:06:42 -0800 | [diff] [blame] | 251 | static inline void bcma_block_read(struct bcma_device *core, void *buffer, | 
| Rafał Miłecki | 9d75ef0 | 2011-05-20 03:27:06 +0200 | [diff] [blame] | 252 | size_t count, u16 offset, u8 reg_width) | 
|  | 253 | { | 
|  | 254 | core->bus->ops->block_read(core, buffer, count, offset, reg_width); | 
|  | 255 | } | 
| Arend van Spriel | 0844555 | 2011-12-08 15:06:42 -0800 | [diff] [blame] | 256 | static inline void bcma_block_write(struct bcma_device *core, | 
|  | 257 | const void *buffer, size_t count, | 
|  | 258 | u16 offset, u8 reg_width) | 
| Rafał Miłecki | 9d75ef0 | 2011-05-20 03:27:06 +0200 | [diff] [blame] | 259 | { | 
|  | 260 | core->bus->ops->block_write(core, buffer, count, offset, reg_width); | 
|  | 261 | } | 
|  | 262 | #endif | 
| Arend van Spriel | 0844555 | 2011-12-08 15:06:42 -0800 | [diff] [blame] | 263 | static inline u32 bcma_aread32(struct bcma_device *core, u16 offset) | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 264 | { | 
|  | 265 | return core->bus->ops->aread32(core, offset); | 
|  | 266 | } | 
| Arend van Spriel | 0844555 | 2011-12-08 15:06:42 -0800 | [diff] [blame] | 267 | static inline | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 268 | void bcma_awrite32(struct bcma_device *core, u16 offset, u32 value) | 
|  | 269 | { | 
|  | 270 | core->bus->ops->awrite32(core, offset, value); | 
|  | 271 | } | 
|  | 272 |  | 
| Arend van Spriel | 9d08f10 | 2011-12-08 15:06:41 -0800 | [diff] [blame] | 273 | static inline void bcma_mask32(struct bcma_device *cc, u16 offset, u32 mask) | 
|  | 274 | { | 
|  | 275 | bcma_write32(cc, offset, bcma_read32(cc, offset) & mask); | 
|  | 276 | } | 
|  | 277 | static inline void bcma_set32(struct bcma_device *cc, u16 offset, u32 set) | 
|  | 278 | { | 
|  | 279 | bcma_write32(cc, offset, bcma_read32(cc, offset) | set); | 
|  | 280 | } | 
|  | 281 | static inline void bcma_maskset32(struct bcma_device *cc, | 
|  | 282 | u16 offset, u32 mask, u32 set) | 
|  | 283 | { | 
|  | 284 | bcma_write32(cc, offset, (bcma_read32(cc, offset) & mask) | set); | 
|  | 285 | } | 
|  | 286 | static inline void bcma_mask16(struct bcma_device *cc, u16 offset, u16 mask) | 
|  | 287 | { | 
|  | 288 | bcma_write16(cc, offset, bcma_read16(cc, offset) & mask); | 
|  | 289 | } | 
|  | 290 | static inline void bcma_set16(struct bcma_device *cc, u16 offset, u16 set) | 
|  | 291 | { | 
|  | 292 | bcma_write16(cc, offset, bcma_read16(cc, offset) | set); | 
|  | 293 | } | 
|  | 294 | static inline void bcma_maskset16(struct bcma_device *cc, | 
|  | 295 | u16 offset, u16 mask, u16 set) | 
|  | 296 | { | 
|  | 297 | bcma_write16(cc, offset, (bcma_read16(cc, offset) & mask) | set); | 
|  | 298 | } | 
| Rafał Miłecki | 3de1a77 | 2011-07-17 01:06:03 +0200 | [diff] [blame] | 299 |  | 
| Hauke Mehrtens | 1c9351c | 2012-02-28 00:56:09 +0100 | [diff] [blame] | 300 | extern struct bcma_device *bcma_find_core(struct bcma_bus *bus, u16 coreid); | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 301 | extern bool bcma_core_is_enabled(struct bcma_device *core); | 
| Arend van Spriel | e3ae0ca | 2011-06-09 20:07:20 +0200 | [diff] [blame] | 302 | extern void bcma_core_disable(struct bcma_device *core, u32 flags); | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 303 | extern int bcma_core_enable(struct bcma_device *core, u32 flags); | 
| Rafał Miłecki | 7424dd0 | 2011-07-17 01:06:04 +0200 | [diff] [blame] | 304 | extern void bcma_core_set_clockmode(struct bcma_device *core, | 
|  | 305 | enum bcma_clkmode clkmode); | 
| Rafał Miłecki | 6f53912 | 2011-07-17 01:06:05 +0200 | [diff] [blame] | 306 | extern void bcma_core_pll_ctl(struct bcma_device *core, u32 req, u32 status, | 
|  | 307 | bool on); | 
| Rafał Miłecki | 05aec23 | 2011-07-20 19:52:15 +0200 | [diff] [blame] | 308 | #define BCMA_DMA_TRANSLATION_MASK	0xC0000000 | 
|  | 309 | #define  BCMA_DMA_TRANSLATION_NONE	0x00000000 | 
|  | 310 | #define  BCMA_DMA_TRANSLATION_DMA32_CMT	0x40000000 /* Client Mode Translation for 32-bit DMA */ | 
|  | 311 | #define  BCMA_DMA_TRANSLATION_DMA64_CMT	0x80000000 /* Client Mode Translation for 64-bit DMA */ | 
|  | 312 | extern u32 bcma_core_dma_translation(struct bcma_device *core); | 
| Rafał Miłecki | 3de1a77 | 2011-07-17 01:06:03 +0200 | [diff] [blame] | 313 |  | 
| Rafał Miłecki | 8369ae3 | 2011-05-09 18:56:46 +0200 | [diff] [blame] | 314 | #endif /* LINUX_BCMA_H_ */ |