cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

pinctrl-tegra.h (6326B)


      1/* SPDX-License-Identifier: GPL-2.0-only */
      2/*
      3 * Driver for the NVIDIA Tegra pinmux
      4 *
      5 * Copyright (c) 2011, NVIDIA CORPORATION.  All rights reserved.
      6 */
      7
      8#ifndef __PINMUX_TEGRA_H__
      9#define __PINMUX_TEGRA_H__
     10
     11struct tegra_pmx {
     12	struct device *dev;
     13	struct pinctrl_dev *pctl;
     14
     15	const struct tegra_pinctrl_soc_data *soc;
     16	const char **group_pins;
     17
     18	int nbanks;
     19	void __iomem **regs;
     20	u32 *backup_regs;
     21};
     22
     23enum tegra_pinconf_param {
     24	/* argument: tegra_pinconf_pull */
     25	TEGRA_PINCONF_PARAM_PULL,
     26	/* argument: tegra_pinconf_tristate */
     27	TEGRA_PINCONF_PARAM_TRISTATE,
     28	/* argument: Boolean */
     29	TEGRA_PINCONF_PARAM_ENABLE_INPUT,
     30	/* argument: Boolean */
     31	TEGRA_PINCONF_PARAM_OPEN_DRAIN,
     32	/* argument: Boolean */
     33	TEGRA_PINCONF_PARAM_LOCK,
     34	/* argument: Boolean */
     35	TEGRA_PINCONF_PARAM_IORESET,
     36	/* argument: Boolean */
     37	TEGRA_PINCONF_PARAM_RCV_SEL,
     38	/* argument: Boolean */
     39	TEGRA_PINCONF_PARAM_HIGH_SPEED_MODE,
     40	/* argument: Boolean */
     41	TEGRA_PINCONF_PARAM_SCHMITT,
     42	/* argument: Boolean */
     43	TEGRA_PINCONF_PARAM_LOW_POWER_MODE,
     44	/* argument: Integer, range is HW-dependant */
     45	TEGRA_PINCONF_PARAM_DRIVE_DOWN_STRENGTH,
     46	/* argument: Integer, range is HW-dependant */
     47	TEGRA_PINCONF_PARAM_DRIVE_UP_STRENGTH,
     48	/* argument: Integer, range is HW-dependant */
     49	TEGRA_PINCONF_PARAM_SLEW_RATE_FALLING,
     50	/* argument: Integer, range is HW-dependant */
     51	TEGRA_PINCONF_PARAM_SLEW_RATE_RISING,
     52	/* argument: Integer, range is HW-dependant */
     53	TEGRA_PINCONF_PARAM_DRIVE_TYPE,
     54};
     55
     56enum tegra_pinconf_pull {
     57	TEGRA_PINCONFIG_PULL_NONE,
     58	TEGRA_PINCONFIG_PULL_DOWN,
     59	TEGRA_PINCONFIG_PULL_UP,
     60};
     61
     62enum tegra_pinconf_tristate {
     63	TEGRA_PINCONFIG_DRIVEN,
     64	TEGRA_PINCONFIG_TRISTATE,
     65};
     66
     67#define TEGRA_PINCONF_PACK(_param_, _arg_) ((_param_) << 16 | (_arg_))
     68#define TEGRA_PINCONF_UNPACK_PARAM(_conf_) ((_conf_) >> 16)
     69#define TEGRA_PINCONF_UNPACK_ARG(_conf_) ((_conf_) & 0xffff)
     70
     71/**
     72 * struct tegra_function - Tegra pinctrl mux function
     73 * @name: The name of the function, exported to pinctrl core.
     74 * @groups: An array of pin groups that may select this function.
     75 * @ngroups: The number of entries in @groups.
     76 */
     77struct tegra_function {
     78	const char *name;
     79	const char **groups;
     80	unsigned ngroups;
     81};
     82
     83/**
     84 * struct tegra_pingroup - Tegra pin group
     85 * @name		The name of the pin group.
     86 * @pins		An array of pin IDs included in this pin group.
     87 * @npins		The number of entries in @pins.
     88 * @funcs		The mux functions which can be muxed onto this group.
     89 * @mux_reg:		Mux register offset.
     90 *			This register contains the mux, einput, odrain, lock,
     91 *			ioreset, rcv_sel parameters.
     92 * @mux_bank:		Mux register bank.
     93 * @mux_bit:		Mux register bit.
     94 * @pupd_reg:		Pull-up/down register offset.
     95 * @pupd_bank:		Pull-up/down register bank.
     96 * @pupd_bit:		Pull-up/down register bit.
     97 * @tri_reg:		Tri-state register offset.
     98 * @tri_bank:		Tri-state register bank.
     99 * @tri_bit:		Tri-state register bit.
    100 * @einput_bit:		Enable-input register bit.
    101 * @odrain_bit:		Open-drain register bit.
    102 * @lock_bit:		Lock register bit.
    103 * @ioreset_bit:	IO reset register bit.
    104 * @rcv_sel_bit:	Receiver select bit.
    105 * @drv_reg:		Drive fields register offset.
    106 *			This register contains hsm, schmitt, lpmd, drvdn,
    107 *			drvup, slwr, slwf, and drvtype parameters.
    108 * @drv_bank:		Drive fields register bank.
    109 * @hsm_bit:		High Speed Mode register bit.
    110 * @sfsel_bit:		GPIO/SFIO selection register bit.
    111 * @schmitt_bit:	Schmitt register bit.
    112 * @lpmd_bit:		Low Power Mode register bit.
    113 * @drvdn_bit:		Drive Down register bit.
    114 * @drvdn_width:	Drive Down field width.
    115 * @drvup_bit:		Drive Up register bit.
    116 * @drvup_width:	Drive Up field width.
    117 * @slwr_bit:		Slew Rising register bit.
    118 * @slwr_width:		Slew Rising field width.
    119 * @slwf_bit:		Slew Falling register bit.
    120 * @slwf_width:		Slew Falling field width.
    121 * @lpdr_bit:		Base driver enabling bit.
    122 * @drvtype_bit:	Drive type register bit.
    123 * @parked_bitmask:	Parked register mask. 0 if unsupported.
    124 *
    125 * -1 in a *_reg field means that feature is unsupported for this group.
    126 * *_bank and *_reg values are irrelevant when *_reg is -1.
    127 * When *_reg is valid, *_bit may be -1 to indicate an unsupported feature.
    128 *
    129 * A representation of a group of pins (possibly just one pin) in the Tegra
    130 * pin controller. Each group allows some parameter or parameters to be
    131 * configured. The most common is mux function selection. Many others exist
    132 * such as pull-up/down, tri-state, etc. Tegra's pin controller is complex;
    133 * certain groups may only support configuring certain parameters, hence
    134 * each parameter is optional.
    135 */
    136struct tegra_pingroup {
    137	const char *name;
    138	const unsigned *pins;
    139	u8 npins;
    140	u8 funcs[4];
    141	s32 mux_reg;
    142	s32 pupd_reg;
    143	s32 tri_reg;
    144	s32 drv_reg;
    145	u32 mux_bank:2;
    146	u32 pupd_bank:2;
    147	u32 tri_bank:2;
    148	u32 drv_bank:2;
    149	s32 mux_bit:6;
    150	s32 pupd_bit:6;
    151	s32 tri_bit:6;
    152	s32 einput_bit:6;
    153	s32 odrain_bit:6;
    154	s32 lock_bit:6;
    155	s32 ioreset_bit:6;
    156	s32 rcv_sel_bit:6;
    157	s32 hsm_bit:6;
    158	s32 sfsel_bit:6;
    159	s32 schmitt_bit:6;
    160	s32 lpmd_bit:6;
    161	s32 drvdn_bit:6;
    162	s32 drvup_bit:6;
    163	s32 slwr_bit:6;
    164	s32 slwf_bit:6;
    165	s32 lpdr_bit:6;
    166	s32 drvtype_bit:6;
    167	s32 drvdn_width:6;
    168	s32 drvup_width:6;
    169	s32 slwr_width:6;
    170	s32 slwf_width:6;
    171	u32 parked_bitmask;
    172};
    173
    174/**
    175 * struct tegra_pinctrl_soc_data - Tegra pin controller driver configuration
    176 * @ngpios:	The number of GPIO pins the pin controller HW affects.
    177 * @pins:	An array describing all pins the pin controller affects.
    178 *		All pins which are also GPIOs must be listed first within the
    179 *		array, and be numbered identically to the GPIO controller's
    180 *		numbering.
    181 * @npins:	The numbmer of entries in @pins.
    182 * @functions:	An array describing all mux functions the SoC supports.
    183 * @nfunctions:	The numbmer of entries in @functions.
    184 * @groups:	An array describing all pin groups the pin SoC supports.
    185 * @ngroups:	The numbmer of entries in @groups.
    186 */
    187struct tegra_pinctrl_soc_data {
    188	unsigned ngpios;
    189	const char *gpio_compatible;
    190	const struct pinctrl_pin_desc *pins;
    191	unsigned npins;
    192	struct tegra_function *functions;
    193	unsigned nfunctions;
    194	const struct tegra_pingroup *groups;
    195	unsigned ngroups;
    196	bool hsm_in_mux;
    197	bool schmitt_in_mux;
    198	bool drvtype_in_mux;
    199	bool sfsel_in_mux;
    200};
    201
    202extern const struct dev_pm_ops tegra_pinctrl_pm;
    203
    204int tegra_pinctrl_probe(struct platform_device *pdev,
    205			const struct tegra_pinctrl_soc_data *soc_data);
    206#endif