72 lines
2.2 KiB
C
72 lines
2.2 KiB
C
|
/* arch/arm/mach-msm/gpio_chip.h
|
||
|
*
|
||
|
* Copyright (C) 2007 Google, Inc.
|
||
|
*
|
||
|
* This software is licensed under the terms of the GNU General Public
|
||
|
* License version 2, as published by the Free Software Foundation, and
|
||
|
* may be copied, distributed, and modified under those terms.
|
||
|
*
|
||
|
* This program is distributed in the hope that it will be useful,
|
||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
* GNU General Public License for more details.
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
#ifndef _LINUX_GPIO_CHIP_H
|
||
|
#define _LINUX_GPIO_CHIP_H
|
||
|
|
||
|
#include <linux/list.h>
|
||
|
#include <linux/gpio.h>
|
||
|
|
||
|
#define GPIOF_IRQF_MASK 0x0000ffff /* use to specify edge detection without */
|
||
|
#define GPIOF_IRQF_TRIGGER_NONE 0x00010000 /* IRQF_TRIGGER_NONE is 0 which also means "as already configured" */
|
||
|
#define GPIOF_INPUT 0x00020000
|
||
|
#define GPIOF_DRIVE_OUTPUT 0x00040000
|
||
|
#define GPIOF_OUTPUT_LOW 0x00080000
|
||
|
#define GPIOF_OUTPUT_HIGH 0x00100000
|
||
|
|
||
|
#define MSM_GPIO_BROKEN_INT_CLEAR 1
|
||
|
|
||
|
struct old_gpio_chip {
|
||
|
struct gpio_chip gpio_chip;
|
||
|
#define gpio_chip old_gpio_chip
|
||
|
struct device *dev; /* used for pmic8058-gpio*/
|
||
|
|
||
|
spinlock_t lock;
|
||
|
unsigned int start;
|
||
|
unsigned int end;
|
||
|
|
||
|
int (*configure)(struct gpio_chip *chip, unsigned int gpio, unsigned long flags);
|
||
|
int (*get_irq_num)(struct gpio_chip *chip, unsigned int gpio, unsigned int *irqp, unsigned long *irqnumflagsp);
|
||
|
int (*read)(struct gpio_chip *chip, unsigned int gpio);
|
||
|
int (*write)(struct gpio_chip *chip, unsigned int gpio, unsigned on);
|
||
|
int (*read_detect_status)(struct gpio_chip *chip, unsigned int gpio);
|
||
|
int (*clear_detect_status)(struct gpio_chip *chip, unsigned int gpio);
|
||
|
};
|
||
|
|
||
|
struct msm_gpio_regs {
|
||
|
void __iomem *out;
|
||
|
void __iomem *in;
|
||
|
void __iomem *int_status;
|
||
|
void __iomem *int_clear;
|
||
|
void __iomem *int_en;
|
||
|
void __iomem *int_edge;
|
||
|
void __iomem *int_pos;
|
||
|
void __iomem *oe;
|
||
|
};
|
||
|
|
||
|
struct msm_gpio_chip {
|
||
|
struct gpio_chip chip;
|
||
|
struct msm_gpio_regs regs;
|
||
|
#if MSM_GPIO_BROKEN_INT_CLEAR
|
||
|
unsigned int_status_copy;
|
||
|
#endif
|
||
|
unsigned int both_edge_detect;
|
||
|
unsigned int int_enable[2]; /* 0: awake, 1: sleep */
|
||
|
};
|
||
|
|
||
|
int register_gpio_chip(struct gpio_chip *gpio_chip);
|
||
|
|
||
|
#endif
|