* @lock:                      Used for register access protection
  * @irq_base:          Save base of IRQ number for interrupt
  * @ioh:               IOH ID
- * @spinlock:          Used for register access protection in
- *                             interrupt context pch_irq_mask,
- *                             pch_irq_unmask and pch_irq_type;
+ * @spinlock:          Used for register access protection
  */
 struct pch_gpio {
        void __iomem *base;
        struct device *dev;
        struct gpio_chip gpio;
        struct pch_gpio_reg_data pch_gpio_reg;
-       struct mutex lock;
        int irq_base;
        enum pch_type_t ioh;
        spinlock_t spinlock;
 {
        u32 reg_val;
        struct pch_gpio *chip = container_of(gpio, struct pch_gpio, gpio);
+       unsigned long flags;
 
-       mutex_lock(&chip->lock);
+       spin_lock_irqsave(&chip->spinlock, flags);
        reg_val = ioread32(&chip->reg->po);
        if (val)
                reg_val |= (1 << nr);
                reg_val &= ~(1 << nr);
 
        iowrite32(reg_val, &chip->reg->po);
-       mutex_unlock(&chip->lock);
+       spin_unlock_irqrestore(&chip->spinlock, flags);
 }
 
 static int pch_gpio_get(struct gpio_chip *gpio, unsigned nr)
        struct pch_gpio *chip = container_of(gpio, struct pch_gpio, gpio);
        u32 pm;
        u32 reg_val;
+       unsigned long flags;
 
-       mutex_lock(&chip->lock);
+       spin_lock_irqsave(&chip->spinlock, flags);
        pm = ioread32(&chip->reg->pm) & ((1 << gpio_pins[chip->ioh]) - 1);
        pm |= (1 << nr);
        iowrite32(pm, &chip->reg->pm);
        else
                reg_val &= ~(1 << nr);
        iowrite32(reg_val, &chip->reg->po);
-
-       mutex_unlock(&chip->lock);
+       spin_unlock_irqrestore(&chip->spinlock, flags);
 
        return 0;
 }
 {
        struct pch_gpio *chip = container_of(gpio, struct pch_gpio, gpio);
        u32 pm;
+       unsigned long flags;
 
-       mutex_lock(&chip->lock);
+       spin_lock_irqsave(&chip->spinlock, flags);
        pm = ioread32(&chip->reg->pm) & ((1 << gpio_pins[chip->ioh]) - 1);
        pm &= ~(1 << nr);
        iowrite32(pm, &chip->reg->pm);
-       mutex_unlock(&chip->lock);
+       spin_unlock_irqrestore(&chip->spinlock, flags);
 
        return 0;
 }
 
        chip->reg = chip->base;
        pci_set_drvdata(pdev, chip);
-       mutex_init(&chip->lock);
        spin_lock_init(&chip->spinlock);
        pch_gpio_setup(chip);
        ret = gpiochip_add(&chip->gpio);