#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/platform_device.h>
#include <linux/gpio/driver.h>
#include <linux/platform_data/gpio/gpio-amd-fch.h>
#include <linux/spinlock.h>
#define AMD_FCH_MMIO_BASE 0xFED80000
#define AMD_FCH_GPIO_BANK0_BASE 0x1500
#define AMD_FCH_GPIO_SIZE 0x0300
#define AMD_FCH_GPIO_FLAG_DIRECTION BIT(23)
#define AMD_FCH_GPIO_FLAG_WRITE BIT(22)
#define AMD_FCH_GPIO_FLAG_READ BIT(16)
static struct resource amd_fch_gpio_iores =
AMD_FCH_MMIO_BASE + AMD_FCH_GPIO_BANK0_BASE,
struct amd_fch_gpio_priv {
struct platform_device *pdev;
struct amd_fch_gpio_pdata *pdata;
static void __iomem *amd_fch_gpio_addr(struct amd_fch_gpio_priv *priv,
return priv->base + priv->pdata->gpio_reg[gpio]*sizeof(u32);
static int amd_fch_gpio_direction_input(struct gpio_chip *gc,
struct amd_fch_gpio_priv *priv = gpiochip_get_data(gc);
void __iomem *ptr = amd_fch_gpio_addr(priv, offset);
spin_lock_irqsave(&priv->lock, flags);
writel_relaxed(readl_relaxed(ptr) & ~AMD_FCH_GPIO_FLAG_DIRECTION, ptr);
spin_unlock_irqrestore(&priv->lock, flags);
static int amd_fch_gpio_direction_output(struct gpio_chip *gc,
unsigned int gpio, int value)