2007-03-14 03:19:24 +02:00
|
|
|
#ifndef __SWITCH_GPIO_H
|
|
|
|
#define __SWITCH_GPIO_H
|
|
|
|
|
2008-02-19 17:22:17 +02:00
|
|
|
#include <linux/ssb/ssb_embedded.h>
|
2011-08-04 23:07:58 +03:00
|
|
|
#include <linux/bcma/bcma_driver_chipcommon.h>
|
|
|
|
#include <bcm47xx.h>
|
2007-03-14 03:19:24 +02:00
|
|
|
|
|
|
|
static inline u32 gpio_in(void)
|
|
|
|
{
|
2011-08-04 23:07:58 +03:00
|
|
|
switch (bcm47xx_bus_type) {
|
|
|
|
#ifdef CONFIG_BCM47XX_SSB
|
|
|
|
case BCM47XX_BUS_TYPE_SSB:
|
|
|
|
return ssb_gpio_in(&bcm47xx_bus.ssb, ~0);
|
|
|
|
#endif
|
|
|
|
#ifdef CONFIG_BCM47XX_BCMA
|
|
|
|
case BCM47XX_BUS_TYPE_BCMA:
|
|
|
|
return bcma_chipco_gpio_in(&bcm47xx_bus.bcma.bus.drv_cc, ~0);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
return -EINVAL;
|
2007-03-14 03:19:24 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline u32 gpio_out(u32 mask, u32 value)
|
|
|
|
{
|
2011-08-04 23:07:58 +03:00
|
|
|
switch (bcm47xx_bus_type) {
|
|
|
|
#ifdef CONFIG_BCM47XX_SSB
|
|
|
|
case BCM47XX_BUS_TYPE_SSB:
|
|
|
|
return ssb_gpio_out(&bcm47xx_bus.ssb, mask, value);
|
|
|
|
#endif
|
|
|
|
#ifdef CONFIG_BCM47XX_BCMA
|
|
|
|
case BCM47XX_BUS_TYPE_BCMA:
|
|
|
|
return bcma_chipco_gpio_out(&bcm47xx_bus.bcma.bus.drv_cc, mask, value);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
return -EINVAL;
|
2007-03-14 03:19:24 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline u32 gpio_outen(u32 mask, u32 value)
|
|
|
|
{
|
2011-08-04 23:07:58 +03:00
|
|
|
switch (bcm47xx_bus_type) {
|
|
|
|
#ifdef CONFIG_BCM47XX_SSB
|
|
|
|
case BCM47XX_BUS_TYPE_SSB:
|
|
|
|
ssb_gpio_outen(&bcm47xx_bus.ssb, mask, value);
|
|
|
|
return 0;
|
2007-03-14 03:19:24 +02:00
|
|
|
#endif
|
2011-08-04 23:07:58 +03:00
|
|
|
#ifdef CONFIG_BCM47XX_BCMA
|
|
|
|
case BCM47XX_BUS_TYPE_BCMA:
|
|
|
|
bcma_chipco_gpio_outen(&bcm47xx_bus.bcma.bus.drv_cc, mask, value);
|
|
|
|
return 0;
|
2007-03-14 03:19:24 +02:00
|
|
|
#endif
|
2011-08-04 23:07:58 +03:00
|
|
|
}
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
2007-03-14 03:19:24 +02:00
|
|
|
|
|
|
|
#endif /* __SWITCH_GPIO_H */
|