2009-11-27 07:38:01 +00:00
/*
* SuperH Pin Function Controller Support
*
* Copyright ( c ) 2008 Magnus Damm
*
* This file is subject to the terms and conditions of the GNU General Public
* License . See the file " COPYING " in the main directory of this archive
* for more details .
*/
# ifndef __SH_PFC_H
# define __SH_PFC_H
2013-04-09 14:06:01 +00:00
# include <linux/bug.h>
2015-06-30 17:53:59 +01:00
# include <linux/pinctrl/pinconf-generic.h>
2012-07-10 11:59:29 +09:00
# include <linux/stringify.h>
2009-11-27 07:38:01 +00:00
2012-06-21 00:03:41 +09:00
enum {
PINMUX_TYPE_NONE ,
PINMUX_TYPE_FUNCTION ,
PINMUX_TYPE_GPIO ,
PINMUX_TYPE_OUTPUT ,
PINMUX_TYPE_INPUT ,
} ;
2009-11-27 07:38:01 +00:00
2013-03-10 16:44:02 +01:00
# define SH_PFC_PIN_CFG_INPUT (1 << 0)
# define SH_PFC_PIN_CFG_OUTPUT (1 << 1)
# define SH_PFC_PIN_CFG_PULL_UP (1 << 2)
# define SH_PFC_PIN_CFG_PULL_DOWN (1 << 3)
2015-06-30 17:53:59 +01:00
# define SH_PFC_PIN_CFG_IO_VOLTAGE (1 << 4)
2013-07-15 21:10:54 +02:00
# define SH_PFC_PIN_CFG_NO_GPIO (1 << 31)
2013-03-10 16:44:02 +01:00
2013-01-02 14:53:37 +01:00
struct sh_pfc_pin {
2013-02-14 00:59:49 +01:00
u16 pin ;
2013-07-15 13:03:20 +02:00
u16 enum_id ;
2012-07-10 11:59:29 +09:00
const char * name ;
2013-03-10 16:44:02 +01:00
unsigned int configs ;
2009-11-27 07:38:01 +00:00
} ;
2013-01-03 14:33:13 +01:00
# define SH_PFC_PIN_GROUP(n) \
{ \
. name = # n , \
. pins = n # # _pins , \
. mux = n # # _mux , \
. nr_pins = ARRAY_SIZE ( n # # _pins ) , \
}
struct sh_pfc_pin_group {
const char * name ;
const unsigned int * pins ;
const unsigned int * mux ;
unsigned int nr_pins ;
} ;
2015-10-03 02:21:15 +03:00
/*
* Using union vin_data saves memory occupied by the VIN data pins .
* VIN_DATA_PIN_GROUP ( ) is a macro used to describe the VIN pin groups
* in this case .
*/
# define VIN_DATA_PIN_GROUP(n, s) \
{ \
. name = # n # s , \
. pins = n # # _pins . data # # s , \
. mux = n # # _mux . data # # s , \
. nr_pins = ARRAY_SIZE ( n # # _pins . data # # s ) , \
}
union vin_data {
unsigned int data24 [ 24 ] ;
unsigned int data20 [ 20 ] ;
unsigned int data16 [ 16 ] ;
unsigned int data12 [ 12 ] ;
unsigned int data10 [ 10 ] ;
unsigned int data8 [ 8 ] ;
unsigned int data4 [ 4 ] ;
} ;
2013-01-03 14:33:13 +01:00
# define SH_PFC_FUNCTION(n) \
{ \
. name = # n , \
. groups = n # # _groups , \
. nr_groups = ARRAY_SIZE ( n # # _groups ) , \
}
struct sh_pfc_function {
const char * name ;
const char * const * groups ;
unsigned int nr_groups ;
} ;
2012-11-29 13:24:07 +01:00
struct pinmux_func {
2013-07-15 13:03:20 +02:00
u16 enum_id ;
2012-11-29 13:24:07 +01:00
const char * name ;
} ;
2009-11-27 07:38:01 +00:00
struct pinmux_cfg_reg {
2015-03-12 11:09:16 +01:00
u32 reg ;
2015-03-12 11:09:13 +01:00
u8 reg_width , field_width ;
2013-07-15 13:03:20 +02:00
const u16 * enum_ids ;
2015-03-12 11:09:13 +01:00
const u8 * var_field_width ;
2009-11-27 07:38:01 +00:00
} ;
2015-09-23 14:15:08 +02:00
/*
* Describe a config register consisting of several fields of the same width
* - name : Register name ( unused , for documentation purposes only )
* - r : Physical register address
* - r_width : Width of the register ( in bits )
* - f_width : Width of the fixed - width register fields ( in bits )
* This macro must be followed by initialization data : For each register field
* ( from left to right , i . e . MSB to LSB ) , 2 ^ f_width enum IDs must be specified ,
* one for each possible combination of the register field bit values .
*/
2009-11-27 07:38:01 +00:00
# define PINMUX_CFG_REG(name, r, r_width, f_width) \
. reg = r , . reg_width = r_width , . field_width = f_width , \
2013-12-16 20:25:14 +01:00
. enum_ids = ( const u16 [ ( r_width / f_width ) * ( 1 < < f_width ) ] )
2011-12-14 01:01:05 +09:00
2015-09-23 14:15:08 +02:00
/*
* Describe a config register consisting of several fields of different widths
* - name : Register name ( unused , for documentation purposes only )
* - r : Physical register address
* - r_width : Width of the register ( in bits )
* - var_fw0 , var_fwn . . . : List of widths of the register fields ( in bits ) ,
* From left to right ( i . e . MSB to LSB )
* This macro must be followed by initialization data : For each register field
* ( from left to right , i . e . MSB to LSB ) , 2 ^ var_fwi enum IDs must be specified ,
* one for each possible combination of the register field bit values .
*/
2011-12-14 01:01:05 +09:00
# define PINMUX_CFG_REG_VAR(name, r, r_width, var_fw0, var_fwn...) \
. reg = r , . reg_width = r_width , \
2015-03-12 11:09:13 +01:00
. var_field_width = ( const u8 [ r_width ] ) \
2013-12-16 20:25:14 +01:00
{ var_fw0 , var_fwn , 0 } , \
. enum_ids = ( const u16 [ ] )
2009-11-27 07:38:01 +00:00
struct pinmux_data_reg {
2015-03-12 11:09:16 +01:00
u32 reg ;
2015-03-12 11:09:13 +01:00
u8 reg_width ;
2013-07-15 13:03:20 +02:00
const u16 * enum_ids ;
2009-11-27 07:38:01 +00:00
} ;
2015-09-23 14:15:08 +02:00
/*
* Describe a data register
* - name : Register name ( unused , for documentation purposes only )
* - r : Physical register address
* - r_width : Width of the register ( in bits )
* This macro must be followed by initialization data : For each register bit
* ( from left to right , i . e . MSB to LSB ) , one enum ID must be specified .
*/
2009-11-27 07:38:01 +00:00
# define PINMUX_DATA_REG(name, r, r_width) \
. reg = r , . reg_width = r_width , \
2013-12-16 20:25:14 +01:00
. enum_ids = ( const u16 [ r_width ] ) \
2009-11-27 07:38:01 +00:00
2011-09-28 16:50:58 +09:00
struct pinmux_irq {
2013-12-16 20:25:15 +01:00
const short * gpios ;
2011-09-28 16:50:58 +09:00
} ;
2015-09-23 14:15:08 +02:00
/*
* Describe the mapping from GPIOs to a single IRQ
* - ids . . . : List of GPIOs that are mapped to the same IRQ
*/
2015-09-22 10:08:13 +03:00
# define PINMUX_IRQ(ids...) \
2014-05-13 13:37:46 +02:00
{ . gpios = ( const short [ ] ) { ids , - 1 } }
2011-09-28 16:50:58 +09:00
2009-11-27 07:38:01 +00:00
struct pinmux_range {
2013-07-15 13:03:20 +02:00
u16 begin ;
u16 end ;
u16 force ;
2009-11-27 07:38:01 +00:00
} ;
2013-03-10 16:44:02 +01:00
struct sh_pfc ;
struct sh_pfc_soc_operations {
2013-04-21 20:21:57 +02:00
int ( * init ) ( struct sh_pfc * pfc ) ;
2013-03-10 16:44:02 +01:00
unsigned int ( * get_bias ) ( struct sh_pfc * pfc , unsigned int pin ) ;
void ( * set_bias ) ( struct sh_pfc * pfc , unsigned int pin ,
unsigned int bias ) ;
2015-06-30 17:53:59 +01:00
int ( * get_io_voltage ) ( struct sh_pfc * pfc , unsigned int pin ) ;
int ( * set_io_voltage ) ( struct sh_pfc * pfc , unsigned int pin ,
u16 voltage_mV ) ;
2013-03-10 16:44:02 +01:00
} ;
2012-12-15 23:51:20 +01:00
struct sh_pfc_soc_info {
2013-02-16 18:47:05 +01:00
const char * name ;
2013-03-10 16:44:02 +01:00
const struct sh_pfc_soc_operations * ops ;
2009-11-27 07:38:01 +00:00
struct pinmux_range input ;
struct pinmux_range output ;
struct pinmux_range function ;
2013-02-16 18:47:05 +01:00
const struct sh_pfc_pin * pins ;
2012-11-29 12:24:51 +01:00
unsigned int nr_pins ;
2013-01-03 14:33:13 +01:00
const struct sh_pfc_pin_group * groups ;
unsigned int nr_groups ;
const struct sh_pfc_function * functions ;
unsigned int nr_functions ;
2015-08-04 15:55:19 +02:00
# ifdef CONFIG_SUPERH
2013-02-16 18:47:05 +01:00
const struct pinmux_func * func_gpios ;
2012-11-29 13:24:07 +01:00
unsigned int nr_func_gpios ;
2015-08-04 15:55:19 +02:00
# endif
2012-11-28 17:51:00 +01:00
2013-02-16 18:47:05 +01:00
const struct pinmux_cfg_reg * cfg_regs ;
const struct pinmux_data_reg * data_regs ;
2009-11-27 07:38:01 +00:00
2015-09-21 16:27:23 +02:00
const u16 * pinmux_data ;
unsigned int pinmux_data_size ;
2009-11-27 07:38:01 +00:00
2013-02-16 18:47:05 +01:00
const struct pinmux_irq * gpio_irq ;
2011-09-28 16:50:58 +09:00
unsigned int gpio_irq_size ;
2015-03-12 11:09:16 +01:00
u32 unlock_reg ;
2009-11-27 07:38:01 +00:00
} ;
2013-07-15 15:14:22 +02:00
/* -----------------------------------------------------------------------------
* Helper macros to create pin and port lists
*/
/*
2015-09-21 16:27:23 +02:00
* sh_pfc_soc_info pinmux_data array macros
2013-07-15 15:14:22 +02:00
*/
2015-09-23 14:15:08 +02:00
/*
* Describe generic pinmux data
* - data_or_mark : * _DATA or * _MARK enum ID
* - ids . . . : List of enum IDs to associate with data_or_mark
*/
2013-07-15 15:14:22 +02:00
# define PINMUX_DATA(data_or_mark, ids...) data_or_mark, ids, 0
2015-09-23 14:15:08 +02:00
/*
* Describe a pinmux configuration without GPIO function that needs
* configuration in a Peripheral Function Select Register ( IPSR )
* - ipsr : IPSR field ( unused , for documentation purposes only )
* - fn : Function name , referring to a field in the IPSR
*/
# define PINMUX_IPSR_NOGP(ipsr, fn) \
2013-07-15 15:14:22 +02:00
PINMUX_DATA ( fn # # _MARK , FN_ # # fn )
2015-09-23 14:15:08 +02:00
/*
* Describe a pinmux configuration with GPIO function that needs configuration
* in both a Peripheral Function Select Register ( IPSR ) and in a
* GPIO / Peripheral Function Select Register ( GPSR )
* - ipsr : IPSR field
* - fn : Function name , also referring to the IPSR field
*/
2015-11-30 13:34:47 +01:00
# define PINMUX_IPSR_GPSR(ipsr, fn) \
2013-07-15 15:14:22 +02:00
PINMUX_DATA ( fn # # _MARK , FN_ # # fn , FN_ # # ipsr )
2015-09-23 14:15:08 +02:00
/*
* Describe a pinmux configuration without GPIO function that needs
* configuration in a Peripheral Function Select Register ( IPSR ) , and where the
* pinmux function has a representation in a Module Select Register ( MOD_SEL ) .
* - ipsr : IPSR field ( unused , for documentation purposes only )
* - fn : Function name , also referring to the IPSR field
* - msel : Module selector
*/
# define PINMUX_IPSR_NOGM(ipsr, fn, msel) \
PINMUX_DATA ( fn # # _MARK , FN_ # # fn , FN_ # # msel )
/*
* Describe a pinmux configuration with GPIO function where the pinmux function
* has no representation in a Peripheral Function Select Register ( IPSR ) , but
* instead solely depends on a group selection .
* - gpsr : GPSR field
* - fn : Function name , also referring to the GPSR field
* - gsel : Group selector
*/
# define PINMUX_IPSR_NOFN(gpsr, fn, gsel) \
PINMUX_DATA ( fn # # _MARK , FN_ # # gpsr , FN_ # # gsel )
/*
* Describe a pinmux configuration with GPIO function that needs configuration
* in both a Peripheral Function Select Register ( IPSR ) and a GPIO / Peripheral
* Function Select Register ( GPSR ) , and where the pinmux function has a
* representation in a Module Select Register ( MOD_SEL ) .
* - ipsr : IPSR field
* - fn : Function name , also referring to the IPSR field
* - msel : Module selector
*/
# define PINMUX_IPSR_MSEL(ipsr, fn, msel) \
PINMUX_DATA ( fn # # _MARK , FN_ # # msel , FN_ # # ipsr , FN_ # # fn )
2013-07-15 15:14:22 +02:00
2015-10-20 19:33:00 +02:00
/*
* Describe a pinmux configuration for a single - function pin with GPIO
* capability .
* - fn : Function name
*/
# define PINMUX_SINGLE(fn) \
PINMUX_DATA ( fn # # _MARK , FN_ # # fn )
2013-07-15 15:14:22 +02:00
/*
* GP port style ( 32 ports banks )
*/
2015-10-05 16:55:53 +02:00
# define PORT_GP_CFG_1(bank, pin, fn, sfx, cfg) fn(bank, pin, GP_##bank##_##pin, sfx, cfg)
# define PORT_GP_1(bank, pin, fn, sfx) PORT_GP_CFG_1(bank, pin, fn, sfx, 0)
2015-11-11 14:29:59 +09:00
# define PORT_GP_CFG_4(bank, fn, sfx, cfg) \
2015-10-05 16:55:53 +02:00
PORT_GP_CFG_1 ( bank , 0 , fn , sfx , cfg ) , PORT_GP_CFG_1 ( bank , 1 , fn , sfx , cfg ) , \
2015-11-11 14:29:59 +09:00
PORT_GP_CFG_1 ( bank , 2 , fn , sfx , cfg ) , PORT_GP_CFG_1 ( bank , 3 , fn , sfx , cfg )
# define PORT_GP_4(bank, fn, sfx) PORT_GP_CFG_4(bank, fn, sfx, 0)
# define PORT_GP_CFG_8(bank, fn, sfx, cfg) \
PORT_GP_CFG_4 ( bank , fn , sfx , cfg ) , \
2015-10-05 16:55:53 +02:00
PORT_GP_CFG_1 ( bank , 4 , fn , sfx , cfg ) , PORT_GP_CFG_1 ( bank , 5 , fn , sfx , cfg ) , \
2015-11-11 14:29:59 +09:00
PORT_GP_CFG_1 ( bank , 6 , fn , sfx , cfg ) , PORT_GP_CFG_1 ( bank , 7 , fn , sfx , cfg )
# define PORT_GP_8(bank, fn, sfx) PORT_GP_CFG_8(bank, fn, sfx, 0)
# define PORT_GP_CFG_9(bank, fn, sfx, cfg) \
PORT_GP_CFG_8 ( bank , fn , sfx , cfg ) , \
PORT_GP_CFG_1 ( bank , 8 , fn , sfx , cfg )
# define PORT_GP_9(bank, fn, sfx) PORT_GP_CFG_9(bank, fn, sfx, 0)
# define PORT_GP_CFG_12(bank, fn, sfx, cfg) \
PORT_GP_CFG_8 ( bank , fn , sfx , cfg ) , \
2015-10-05 16:55:53 +02:00
PORT_GP_CFG_1 ( bank , 8 , fn , sfx , cfg ) , PORT_GP_CFG_1 ( bank , 9 , fn , sfx , cfg ) , \
2015-11-11 14:29:59 +09:00
PORT_GP_CFG_1 ( bank , 10 , fn , sfx , cfg ) , PORT_GP_CFG_1 ( bank , 11 , fn , sfx , cfg )
# define PORT_GP_12(bank, fn, sfx) PORT_GP_CFG_12(bank, fn, sfx, 0)
# define PORT_GP_CFG_14(bank, fn, sfx, cfg) \
PORT_GP_CFG_12 ( bank , fn , sfx , cfg ) , \
PORT_GP_CFG_1 ( bank , 12 , fn , sfx , cfg ) , PORT_GP_CFG_1 ( bank , 13 , fn , sfx , cfg )
# define PORT_GP_14(bank, fn, sfx) PORT_GP_CFG_14(bank, fn, sfx, 0)
# define PORT_GP_CFG_15(bank, fn, sfx, cfg) \
PORT_GP_CFG_14 ( bank , fn , sfx , cfg ) , \
PORT_GP_CFG_1 ( bank , 14 , fn , sfx , cfg )
# define PORT_GP_15(bank, fn, sfx) PORT_GP_CFG_15(bank, fn, sfx, 0)
# define PORT_GP_CFG_16(bank, fn, sfx, cfg) \
PORT_GP_CFG_14 ( bank , fn , sfx , cfg ) , \
PORT_GP_CFG_1 ( bank , 14 , fn , sfx , cfg ) , PORT_GP_CFG_1 ( bank , 15 , fn , sfx , cfg )
# define PORT_GP_16(bank, fn, sfx) PORT_GP_CFG_16(bank, fn, sfx, 0)
# define PORT_GP_CFG_18(bank, fn, sfx, cfg) \
PORT_GP_CFG_16 ( bank , fn , sfx , cfg ) , \
PORT_GP_CFG_1 ( bank , 16 , fn , sfx , cfg ) , PORT_GP_CFG_1 ( bank , 17 , fn , sfx , cfg )
# define PORT_GP_18(bank, fn, sfx) PORT_GP_CFG_18(bank, fn, sfx, 0)
# define PORT_GP_CFG_26(bank, fn, sfx, cfg) \
PORT_GP_CFG_18 ( bank , fn , sfx , cfg ) , \
2015-10-05 16:55:53 +02:00
PORT_GP_CFG_1 ( bank , 18 , fn , sfx , cfg ) , PORT_GP_CFG_1 ( bank , 19 , fn , sfx , cfg ) , \
PORT_GP_CFG_1 ( bank , 20 , fn , sfx , cfg ) , PORT_GP_CFG_1 ( bank , 21 , fn , sfx , cfg ) , \
PORT_GP_CFG_1 ( bank , 22 , fn , sfx , cfg ) , PORT_GP_CFG_1 ( bank , 23 , fn , sfx , cfg ) , \
2015-11-11 14:29:59 +09:00
PORT_GP_CFG_1 ( bank , 24 , fn , sfx , cfg ) , PORT_GP_CFG_1 ( bank , 25 , fn , sfx , cfg )
# define PORT_GP_26(bank, fn, sfx) PORT_GP_CFG_26(bank, fn, sfx, 0)
# define PORT_GP_CFG_28(bank, fn, sfx, cfg) \
PORT_GP_CFG_26 ( bank , fn , sfx , cfg ) , \
PORT_GP_CFG_1 ( bank , 26 , fn , sfx , cfg ) , PORT_GP_CFG_1 ( bank , 27 , fn , sfx , cfg )
# define PORT_GP_28(bank, fn, sfx) PORT_GP_CFG_28(bank, fn, sfx, 0)
# define PORT_GP_CFG_30(bank, fn, sfx, cfg) \
PORT_GP_CFG_28 ( bank , fn , sfx , cfg ) , \
PORT_GP_CFG_1 ( bank , 28 , fn , sfx , cfg ) , PORT_GP_CFG_1 ( bank , 29 , fn , sfx , cfg )
# define PORT_GP_30(bank, fn, sfx) PORT_GP_CFG_30(bank, fn, sfx, 0)
# define PORT_GP_CFG_32(bank, fn, sfx, cfg) \
PORT_GP_CFG_30 ( bank , fn , sfx , cfg ) , \
2015-10-05 16:55:53 +02:00
PORT_GP_CFG_1 ( bank , 30 , fn , sfx , cfg ) , PORT_GP_CFG_1 ( bank , 31 , fn , sfx , cfg )
# define PORT_GP_32(bank, fn, sfx) PORT_GP_CFG_32(bank, fn, sfx, 0)
2013-07-15 15:14:22 +02:00
# define PORT_GP_32_REV(bank, fn, sfx) \
PORT_GP_1 ( bank , 31 , fn , sfx ) , PORT_GP_1 ( bank , 30 , fn , sfx ) , \
PORT_GP_1 ( bank , 29 , fn , sfx ) , PORT_GP_1 ( bank , 28 , fn , sfx ) , \
PORT_GP_1 ( bank , 27 , fn , sfx ) , PORT_GP_1 ( bank , 26 , fn , sfx ) , \
PORT_GP_1 ( bank , 25 , fn , sfx ) , PORT_GP_1 ( bank , 24 , fn , sfx ) , \
PORT_GP_1 ( bank , 23 , fn , sfx ) , PORT_GP_1 ( bank , 22 , fn , sfx ) , \
PORT_GP_1 ( bank , 21 , fn , sfx ) , PORT_GP_1 ( bank , 20 , fn , sfx ) , \
PORT_GP_1 ( bank , 19 , fn , sfx ) , PORT_GP_1 ( bank , 18 , fn , sfx ) , \
PORT_GP_1 ( bank , 17 , fn , sfx ) , PORT_GP_1 ( bank , 16 , fn , sfx ) , \
PORT_GP_1 ( bank , 15 , fn , sfx ) , PORT_GP_1 ( bank , 14 , fn , sfx ) , \
PORT_GP_1 ( bank , 13 , fn , sfx ) , PORT_GP_1 ( bank , 12 , fn , sfx ) , \
PORT_GP_1 ( bank , 11 , fn , sfx ) , PORT_GP_1 ( bank , 10 , fn , sfx ) , \
PORT_GP_1 ( bank , 9 , fn , sfx ) , PORT_GP_1 ( bank , 8 , fn , sfx ) , \
PORT_GP_1 ( bank , 7 , fn , sfx ) , PORT_GP_1 ( bank , 6 , fn , sfx ) , \
PORT_GP_1 ( bank , 5 , fn , sfx ) , PORT_GP_1 ( bank , 4 , fn , sfx ) , \
PORT_GP_1 ( bank , 3 , fn , sfx ) , PORT_GP_1 ( bank , 2 , fn , sfx ) , \
PORT_GP_1 ( bank , 1 , fn , sfx ) , PORT_GP_1 ( bank , 0 , fn , sfx )
/* GP_ALL(suffix) - Expand to a list of GP_#_#_suffix */
2015-10-05 16:55:53 +02:00
# define _GP_ALL(bank, pin, name, sfx, cfg) name##_##sfx
2013-07-15 15:14:22 +02:00
# define GP_ALL(str) CPU_ALL_PORT(_GP_ALL, str)
/* PINMUX_GPIO_GP_ALL - Expand to a list of sh_pfc_pin entries */
2015-10-05 16:55:53 +02:00
# define _GP_GPIO(bank, _pin, _name, sfx, cfg) \
2015-06-26 01:40:56 +03:00
{ \
2013-02-14 00:59:49 +01:00
. pin = ( bank * 32 ) + _pin , \
2013-07-15 15:14:22 +02:00
. name = __stringify ( _name ) , \
. enum_id = _name # # _DATA , \
2015-10-05 16:55:53 +02:00
. configs = cfg , \
2013-07-15 15:14:22 +02:00
}
# define PINMUX_GPIO_GP_ALL() CPU_ALL_PORT(_GP_GPIO, unused)
/* PINMUX_DATA_GP_ALL - Expand to a list of name_DATA, name_FN marks */
2015-10-05 16:55:53 +02:00
# define _GP_DATA(bank, pin, name, sfx, cfg) PINMUX_DATA(name##_DATA, name##_FN)
2013-07-15 15:14:22 +02:00
# define PINMUX_DATA_GP_ALL() CPU_ALL_PORT(_GP_DATA, unused)
/*
* PORT style ( linear pin space )
*/
2013-02-14 00:41:57 +01:00
# define PORT_1(pn, fn, pfx, sfx) fn(pn, pfx, sfx)
2013-02-14 00:24:32 +01:00
# define PORT_10(pn, fn, pfx, sfx) \
PORT_1 ( pn , fn , pfx # # 0 , sfx ) , PORT_1 ( pn + 1 , fn , pfx # # 1 , sfx ) , \
PORT_1 ( pn + 2 , fn , pfx # # 2 , sfx ) , PORT_1 ( pn + 3 , fn , pfx # # 3 , sfx ) , \
PORT_1 ( pn + 4 , fn , pfx # # 4 , sfx ) , PORT_1 ( pn + 5 , fn , pfx # # 5 , sfx ) , \
PORT_1 ( pn + 6 , fn , pfx # # 6 , sfx ) , PORT_1 ( pn + 7 , fn , pfx # # 7 , sfx ) , \
PORT_1 ( pn + 8 , fn , pfx # # 8 , sfx ) , PORT_1 ( pn + 9 , fn , pfx # # 9 , sfx )
# define PORT_90(pn, fn, pfx, sfx) \
PORT_10 ( pn + 10 , fn , pfx # # 1 , sfx ) , PORT_10 ( pn + 20 , fn , pfx # # 2 , sfx ) , \
PORT_10 ( pn + 30 , fn , pfx # # 3 , sfx ) , PORT_10 ( pn + 40 , fn , pfx # # 4 , sfx ) , \
PORT_10 ( pn + 50 , fn , pfx # # 5 , sfx ) , PORT_10 ( pn + 60 , fn , pfx # # 6 , sfx ) , \
PORT_10 ( pn + 70 , fn , pfx # # 7 , sfx ) , PORT_10 ( pn + 80 , fn , pfx # # 8 , sfx ) , \
PORT_10 ( pn + 90 , fn , pfx # # 9 , sfx )
2011-11-10 18:45:33 -08:00
2013-07-15 15:14:22 +02:00
/* PORT_ALL(suffix) - Expand to a list of PORT_#_suffix */
2013-02-14 00:41:57 +01:00
# define _PORT_ALL(pn, pfx, sfx) pfx##_##sfx
2013-07-15 15:14:22 +02:00
# define PORT_ALL(str) CPU_ALL_PORT(_PORT_ALL, PORT, str)
2011-11-10 18:45:33 -08:00
2013-07-15 15:14:22 +02:00
/* PINMUX_GPIO - Expand to a sh_pfc_pin entry */
2013-02-14 00:59:49 +01:00
# define PINMUX_GPIO(_pin) \
[ GPIO_ # # _pin ] = { \
. pin = ( u16 ) - 1 , \
2013-11-26 02:45:34 +01:00
. name = __stringify ( GPIO_ # # _pin ) , \
2013-02-14 00:59:49 +01:00
. enum_id = _pin # # _DATA , \
2013-07-15 15:14:22 +02:00
}
2013-07-15 17:42:48 +02:00
/* SH_PFC_PIN_CFG - Expand to a sh_pfc_pin entry (named PORT#) with config */
2013-02-14 00:59:49 +01:00
# define SH_PFC_PIN_CFG(_pin, cfgs) \
2013-07-15 17:42:48 +02:00
{ \
2013-02-14 00:59:49 +01:00
. pin = _pin , \
. name = __stringify ( PORT # # _pin ) , \
. enum_id = PORT # # _pin # # _DATA , \
2013-07-15 17:42:48 +02:00
. configs = cfgs , \
}
2013-07-15 21:10:54 +02:00
/* SH_PFC_PIN_NAMED - Expand to a sh_pfc_pin entry with the given name */
# define SH_PFC_PIN_NAMED(row, col, _name) \
{ \
. pin = PIN_NUMBER ( row , col ) , \
. name = __stringify ( PIN_ # # _name ) , \
. configs = SH_PFC_PIN_CFG_NO_GPIO , \
}
2013-07-15 15:14:22 +02:00
/* PINMUX_DATA_ALL - Expand to a list of PORT_name_DATA, PORT_name_FN0,
* PORT_name_OUT , PORT_name_IN marks
*/
2013-02-14 00:41:57 +01:00
# define _PORT_DATA(pn, pfx, sfx) \
2013-07-15 15:14:22 +02:00
PINMUX_DATA ( PORT # # pfx # # _DATA , PORT # # pfx # # _FN0 , \
PORT # # pfx # # _OUT , PORT # # pfx # # _IN )
# define PINMUX_DATA_ALL() CPU_ALL_PORT(_PORT_DATA, , unused)
/* GPIO_FN(name) - Expand to a sh_pfc_pin entry for a function GPIO */
# define PINMUX_GPIO_FN(gpio, base, data_or_mark) \
[ gpio - ( base ) ] = { \
. name = __stringify ( gpio ) , \
. enum_id = data_or_mark , \
}
# define GPIO_FN(str) \
PINMUX_GPIO_FN ( GPIO_FN_ # # str , PINMUX_FN_BASE , str # # _MARK )
2011-11-10 18:45:23 -08:00
2013-07-15 15:14:22 +02:00
/*
2015-09-23 14:15:08 +02:00
* PORTnCR helper macro for SH - Mobile / R - Mobile
2013-07-15 15:14:22 +02:00
*/
2011-11-10 18:45:43 -08:00
# define PORTCR(nr, reg) \
{ \
2015-02-27 18:38:02 +01:00
PINMUX_CFG_REG_VAR ( " PORT " nr " CR " , reg , 8 , 2 , 2 , 1 , 3 ) { \
/* PULMD[1:0], handled by .set_bias() */ \
0 , 0 , 0 , 0 , \
/* IE and OE */ \
0 , PORT # # nr # # _OUT , PORT # # nr # # _IN , 0 , \
/* SEC, not supported */ \
0 , 0 , \
/* PTMD[2:0] */ \
PORT # # nr # # _FN0 , PORT # # nr # # _FN1 , \
PORT # # nr # # _FN2 , PORT # # nr # # _FN3 , \
PORT # # nr # # _FN4 , PORT # # nr # # _FN5 , \
PORT # # nr # # _FN6 , PORT # # nr # # _FN7 \
} \
2011-11-10 18:45:43 -08:00
}
2011-11-10 18:45:23 -08:00
2015-09-25 10:55:44 +02:00
/*
* GPIO number helper macro for R - Car
*/
# define RCAR_GP_PIN(bank, pin) (((bank) * 32) + (pin))
2009-11-27 07:38:01 +00:00
# endif /* __SH_PFC_H */