| /* |
| * linux/drivers/pinctrl/pinctrl-pxa3xx.h |
| * |
| * This program is free software; you can redistribute it and/or modify |
| * it under the terms of the GNU General Public License version 2 as |
| * publishhed by the Free Software Foundation. |
| * |
| * Copyright (C) 2011, Marvell Technology Group Ltd. |
| * |
| * Author: Haojian Zhuang <haojian.zhuang@marvell.com> |
| * |
| */ |
| |
| #ifndef __PINCTRL_PXA3XX_H |
| |
| #include <linux/pinctrl/pinctrl.h> |
| #include <linux/pinctrl/pinmux.h> |
| |
| #define ARRAY_AND_SIZE(x) (x), ARRAY_SIZE(x) |
| |
| #define PXA3xx_MUX_GPIO 0 |
| |
| #define PXA3xx_MAX_MUX 8 |
| #define MFPR_FUNC_MASK 0x7 |
| |
| enum pxa_cpu_type { |
| PINCTRL_INVALID = 0, |
| PINCTRL_PXA300, |
| PINCTRL_PXA310, |
| PINCTRL_PXA320, |
| PINCTRL_PXA168, |
| PINCTRL_PXA910, |
| PINCTRL_PXA930, |
| PINCTRL_PXA955, |
| PINCTRL_MMP2, |
| PINCTRL_MAX, |
| }; |
| |
| struct pxa3xx_mfp_pin { |
| const char *name; |
| const unsigned int pin; |
| const unsigned int mfpr; /* register offset */ |
| const unsigned short func[8]; |
| }; |
| |
| struct pxa3xx_pin_group { |
| const char *name; |
| const unsigned mux; |
| const unsigned *pins; |
| const unsigned npins; |
| }; |
| |
| struct pxa3xx_pmx_func { |
| const char *name; |
| const char * const * groups; |
| const unsigned num_groups; |
| }; |
| |
| struct pxa3xx_pinmux_info { |
| struct device *dev; |
| struct pinctrl_dev *pctrl; |
| enum pxa_cpu_type cputype; |
| unsigned int phy_base; |
| unsigned int phy_size; |
| void __iomem *virt_base; |
| |
| struct pxa3xx_mfp_pin *mfp; |
| unsigned int num_mfp; |
| struct pxa3xx_pin_group *grps; |
| unsigned int num_grps; |
| struct pxa3xx_pmx_func *funcs; |
| unsigned int num_funcs; |
| unsigned int num_gpio; |
| struct pinctrl_desc *desc; |
| struct pinctrl_pin_desc *pads; |
| unsigned int num_pads; |
| |
| unsigned ds_mask; /* drive strength mask */ |
| unsigned ds_shift; /* drive strength shift */ |
| unsigned slp_mask; /* sleep mask */ |
| unsigned slp_input_low; |
| unsigned slp_input_high; |
| unsigned slp_output_low; |
| unsigned slp_output_high; |
| unsigned slp_float; |
| }; |
| |
| enum pxa3xx_pin_list { |
| GPIO0 = 0, |
| GPIO1, |
| GPIO2, |
| GPIO3, |
| GPIO4, |
| GPIO5, |
| GPIO6, |
| GPIO7, |
| GPIO8, |
| GPIO9, |
| GPIO10, /* 10 */ |
| GPIO11, |
| GPIO12, |
| GPIO13, |
| GPIO14, |
| GPIO15, |
| GPIO16, |
| GPIO17, |
| GPIO18, |
| GPIO19, |
| GPIO20, /* 20 */ |
| GPIO21, |
| GPIO22, |
| GPIO23, |
| GPIO24, |
| GPIO25, |
| GPIO26, |
| GPIO27, |
| GPIO28, |
| GPIO29, |
| GPIO30, /* 30 */ |
| GPIO31, |
| GPIO32, |
| GPIO33, |
| GPIO34, |
| GPIO35, |
| GPIO36, |
| GPIO37, |
| GPIO38, |
| GPIO39, |
| GPIO40, /* 40 */ |
| GPIO41, |
| GPIO42, |
| GPIO43, |
| GPIO44, |
| GPIO45, |
| GPIO46, |
| GPIO47, |
| GPIO48, |
| GPIO49, |
| GPIO50, /* 50 */ |
| GPIO51, |
| GPIO52, |
| GPIO53, |
| GPIO54, |
| GPIO55, |
| GPIO56, |
| GPIO57, |
| GPIO58, |
| GPIO59, |
| GPIO60, /* 60 */ |
| GPIO61, |
| GPIO62, |
| GPIO63, |
| GPIO64, |
| GPIO65, |
| GPIO66, |
| GPIO67, |
| GPIO68, |
| GPIO69, |
| GPIO70, /* 70 */ |
| GPIO71, |
| GPIO72, |
| GPIO73, |
| GPIO74, |
| GPIO75, |
| GPIO76, |
| GPIO77, |
| GPIO78, |
| GPIO79, |
| GPIO80, /* 80 */ |
| GPIO81, |
| GPIO82, |
| GPIO83, |
| GPIO84, |
| GPIO85, |
| GPIO86, |
| GPIO87, |
| GPIO88, |
| GPIO89, |
| GPIO90, /* 90 */ |
| GPIO91, |
| GPIO92, |
| GPIO93, |
| GPIO94, |
| GPIO95, |
| GPIO96, |
| GPIO97, |
| GPIO98, |
| GPIO99, |
| GPIO100, /* 100 */ |
| GPIO101, |
| GPIO102, |
| GPIO103, |
| GPIO104, |
| GPIO105, |
| GPIO106, |
| GPIO107, |
| GPIO108, |
| GPIO109, |
| GPIO110, /* 110 */ |
| GPIO111, |
| GPIO112, |
| GPIO113, |
| GPIO114, |
| GPIO115, |
| GPIO116, |
| GPIO117, |
| GPIO118, |
| GPIO119, |
| GPIO120, /* 120 */ |
| GPIO121, |
| GPIO122, |
| GPIO123, |
| GPIO124, |
| GPIO125, |
| GPIO126, |
| GPIO127, |
| GPIO128, |
| GPIO129, |
| GPIO130, /* 130 */ |
| GPIO131, |
| GPIO132, |
| GPIO133, |
| GPIO134, |
| GPIO135, |
| GPIO136, |
| GPIO137, |
| GPIO138, |
| GPIO139, |
| GPIO140, /* 140 */ |
| GPIO141, |
| GPIO142, |
| GPIO143, |
| GPIO144, |
| GPIO145, |
| GPIO146, |
| GPIO147, |
| GPIO148, |
| GPIO149, |
| GPIO150, /* 150 */ |
| GPIO151, |
| GPIO152, |
| GPIO153, |
| GPIO154, |
| GPIO155, |
| GPIO156, |
| GPIO157, |
| GPIO158, |
| GPIO159, |
| GPIO160, /* 160 */ |
| GPIO161, |
| GPIO162, |
| GPIO163, |
| GPIO164, |
| GPIO165, |
| GPIO166, |
| GPIO167, |
| GPIO168, |
| GPIO169, |
| }; |
| |
| extern int pxa3xx_pinctrl_register(struct platform_device *pdev, |
| struct pxa3xx_pinmux_info *info); |
| extern int pxa3xx_pinctrl_unregister(struct platform_device *pdev); |
| #endif /* __PINCTRL_PXA3XX_H */ |