2018-11-15 20:27:00 +03:00
// SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0
2016-09-23 00:13:42 +03:00
/*
2018-11-15 20:27:00 +03:00
* Mellanox platform driver
2016-09-23 00:13:42 +03:00
*
2018-11-15 20:27:00 +03:00
* Copyright ( C ) 2016 - 2018 Mellanox Technologies
* Copyright ( C ) 2016 - 2018 Vadim Pasternak < vadimp @ mellanox . com >
2016-09-23 00:13:42 +03:00
*/
# include <linux/device.h>
# include <linux/dmi.h>
# include <linux/i2c.h>
# include <linux/i2c-mux.h>
2018-01-23 06:55:11 +03:00
# include <linux/io.h>
2016-09-23 00:13:42 +03:00
# include <linux/module.h>
# include <linux/platform_device.h>
# include <linux/platform_data/i2c-mux-reg.h>
2018-01-17 21:21:53 +03:00
# include <linux/platform_data/mlxreg.h>
2018-01-23 06:55:11 +03:00
# include <linux/regmap.h>
2016-09-23 00:13:42 +03:00
# define MLX_PLAT_DEVICE_NAME "mlxplat"
/* LPC bus IO offsets */
# define MLXPLAT_CPLD_LPC_I2C_BASE_ADRR 0x2000
# define MLXPLAT_CPLD_LPC_REG_BASE_ADRR 0x2500
2018-06-17 19:56:54 +03:00
# define MLXPLAT_CPLD_LPC_REG_CPLD1_VER_OFFSET 0x00
# define MLXPLAT_CPLD_LPC_REG_CPLD2_VER_OFFSET 0x01
2018-11-15 20:26:54 +03:00
# define MLXPLAT_CPLD_LPC_REG_CPLD3_VER_OFFSET 0x02
2019-02-26 11:20:32 +03:00
# define MLXPLAT_CPLD_LPC_REG_CPLD4_VER_OFFSET 0x03
2018-06-17 19:56:54 +03:00
# define MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET 0x1d
2018-11-15 20:26:54 +03:00
# define MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET 0x1e
# define MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET 0x1f
2018-05-07 09:48:53 +03:00
# define MLXPLAT_CPLD_LPC_REG_LED1_OFFSET 0x20
# define MLXPLAT_CPLD_LPC_REG_LED2_OFFSET 0x21
# define MLXPLAT_CPLD_LPC_REG_LED3_OFFSET 0x22
# define MLXPLAT_CPLD_LPC_REG_LED4_OFFSET 0x23
# define MLXPLAT_CPLD_LPC_REG_LED5_OFFSET 0x24
2018-12-13 02:59:11 +03:00
# define MLXPLAT_CPLD_LPC_REG_FAN_DIRECTION 0x2a
2020-01-13 19:28:33 +03:00
# define MLXPLAT_CPLD_LPC_REG_GP0_RO_OFFSET 0x2b
# define MLXPLAT_CPLD_LPC_REG_GP0_OFFSET 0x2e
2018-06-17 19:56:54 +03:00
# define MLXPLAT_CPLD_LPC_REG_GP1_OFFSET 0x30
# define MLXPLAT_CPLD_LPC_REG_WP1_OFFSET 0x31
# define MLXPLAT_CPLD_LPC_REG_GP2_OFFSET 0x32
# define MLXPLAT_CPLD_LPC_REG_WP2_OFFSET 0x33
2018-07-27 01:40:57 +03:00
# define MLXPLAT_CPLD_LPC_REG_PWM_CONTROL_OFFSET 0x37
2018-01-23 06:55:11 +03:00
# define MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET 0x3a
2018-01-26 22:03:44 +03:00
# define MLXPLAT_CPLD_LPC_REG_AGGR_MASK_OFFSET 0x3b
# define MLXPLAT_CPLD_LPC_REG_AGGRLO_OFFSET 0x40
# define MLXPLAT_CPLD_LPC_REG_AGGRLO_MASK_OFFSET 0x41
2019-06-23 15:16:25 +03:00
# define MLXPLAT_CPLD_LPC_REG_AGGRCO_OFFSET 0x42
# define MLXPLAT_CPLD_LPC_REG_AGGRCO_MASK_OFFSET 0x43
2020-01-13 19:28:36 +03:00
# define MLXPLAT_CPLD_LPC_REG_AGGRCX_OFFSET 0x44
# define MLXPLAT_CPLD_LPC_REG_AGGRCX_MASK_OFFSET 0x45
2018-06-17 19:56:54 +03:00
# define MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET 0x50
2018-07-27 01:41:00 +03:00
# define MLXPLAT_CPLD_LPC_REG_ASIC_EVENT_OFFSET 0x51
# define MLXPLAT_CPLD_LPC_REG_ASIC_MASK_OFFSET 0x52
2018-01-23 06:55:11 +03:00
# define MLXPLAT_CPLD_LPC_REG_PSU_OFFSET 0x58
2018-01-26 22:03:44 +03:00
# define MLXPLAT_CPLD_LPC_REG_PSU_EVENT_OFFSET 0x59
# define MLXPLAT_CPLD_LPC_REG_PSU_MASK_OFFSET 0x5a
2018-01-23 06:55:11 +03:00
# define MLXPLAT_CPLD_LPC_REG_PWR_OFFSET 0x64
2018-01-26 22:03:44 +03:00
# define MLXPLAT_CPLD_LPC_REG_PWR_EVENT_OFFSET 0x65
# define MLXPLAT_CPLD_LPC_REG_PWR_MASK_OFFSET 0x66
2018-01-23 06:55:11 +03:00
# define MLXPLAT_CPLD_LPC_REG_FAN_OFFSET 0x88
2018-01-26 22:03:44 +03:00
# define MLXPLAT_CPLD_LPC_REG_FAN_EVENT_OFFSET 0x89
# define MLXPLAT_CPLD_LPC_REG_FAN_MASK_OFFSET 0x8a
2019-03-18 13:58:23 +03:00
# define MLXPLAT_CPLD_LPC_REG_WD_CLEAR_OFFSET 0xc7
# define MLXPLAT_CPLD_LPC_REG_WD_CLEAR_WP_OFFSET 0xc8
# define MLXPLAT_CPLD_LPC_REG_WD1_TMR_OFFSET 0xc9
# define MLXPLAT_CPLD_LPC_REG_WD1_ACT_OFFSET 0xcb
# define MLXPLAT_CPLD_LPC_REG_WD2_TMR_OFFSET 0xcd
# define MLXPLAT_CPLD_LPC_REG_WD2_TLEFT_OFFSET 0xce
# define MLXPLAT_CPLD_LPC_REG_WD2_ACT_OFFSET 0xcf
# define MLXPLAT_CPLD_LPC_REG_WD3_TMR_OFFSET 0xd1
# define MLXPLAT_CPLD_LPC_REG_WD3_TLEFT_OFFSET 0xd2
# define MLXPLAT_CPLD_LPC_REG_WD3_ACT_OFFSET 0xd3
2020-01-13 19:28:33 +03:00
# define MLXPLAT_CPLD_LPC_REG_UFM_VERSION_OFFSET 0xe2
2018-07-27 01:40:57 +03:00
# define MLXPLAT_CPLD_LPC_REG_PWM1_OFFSET 0xe3
# define MLXPLAT_CPLD_LPC_REG_TACHO1_OFFSET 0xe4
# define MLXPLAT_CPLD_LPC_REG_TACHO2_OFFSET 0xe5
# define MLXPLAT_CPLD_LPC_REG_TACHO3_OFFSET 0xe6
# define MLXPLAT_CPLD_LPC_REG_TACHO4_OFFSET 0xe7
# define MLXPLAT_CPLD_LPC_REG_TACHO5_OFFSET 0xe8
# define MLXPLAT_CPLD_LPC_REG_TACHO6_OFFSET 0xe9
2018-11-15 20:26:56 +03:00
# define MLXPLAT_CPLD_LPC_REG_TACHO7_OFFSET 0xeb
# define MLXPLAT_CPLD_LPC_REG_TACHO8_OFFSET 0xec
# define MLXPLAT_CPLD_LPC_REG_TACHO9_OFFSET 0xed
# define MLXPLAT_CPLD_LPC_REG_TACHO10_OFFSET 0xee
# define MLXPLAT_CPLD_LPC_REG_TACHO11_OFFSET 0xef
# define MLXPLAT_CPLD_LPC_REG_TACHO12_OFFSET 0xf0
2018-12-13 02:59:15 +03:00
# define MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET 0xf5
# define MLXPLAT_CPLD_LPC_REG_FAN_CAP2_OFFSET 0xf6
# define MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET 0xf7
2019-03-18 13:58:22 +03:00
# define MLXPLAT_CPLD_LPC_REG_TACHO_SPEED_OFFSET 0xf8
2020-01-13 19:28:37 +03:00
# define MLXPLAT_CPLD_LPC_REG_PSU_I2C_CAP_OFFSET 0xf9
2020-01-13 19:28:33 +03:00
# define MLXPLAT_CPLD_LPC_REG_CONFIG1_OFFSET 0xfb
# define MLXPLAT_CPLD_LPC_REG_CONFIG2_OFFSET 0xfc
2016-09-23 00:13:42 +03:00
# define MLXPLAT_CPLD_LPC_IO_RANGE 0x100
# define MLXPLAT_CPLD_LPC_I2C_CH1_OFF 0xdb
# define MLXPLAT_CPLD_LPC_I2C_CH2_OFF 0xda
2020-01-13 19:28:36 +03:00
# define MLXPLAT_CPLD_LPC_I2C_CH3_OFF 0xdc
2018-07-27 01:40:57 +03:00
2016-09-23 00:13:42 +03:00
# define MLXPLAT_CPLD_LPC_PIO_OFFSET 0x10000UL
# define MLXPLAT_CPLD_LPC_REG1 ((MLXPLAT_CPLD_LPC_REG_BASE_ADRR + \
MLXPLAT_CPLD_LPC_I2C_CH1_OFF ) | \
MLXPLAT_CPLD_LPC_PIO_OFFSET )
# define MLXPLAT_CPLD_LPC_REG2 ((MLXPLAT_CPLD_LPC_REG_BASE_ADRR + \
MLXPLAT_CPLD_LPC_I2C_CH2_OFF ) | \
MLXPLAT_CPLD_LPC_PIO_OFFSET )
2020-01-13 19:28:36 +03:00
# define MLXPLAT_CPLD_LPC_REG3 ((MLXPLAT_CPLD_LPC_REG_BASE_ADRR + \
MLXPLAT_CPLD_LPC_I2C_CH3_OFF ) | \
MLXPLAT_CPLD_LPC_PIO_OFFSET )
2016-09-23 00:13:42 +03:00
2016-12-14 15:05:15 +03:00
/* Masks for aggregation, psu, pwr and fan event in CPLD related registers. */
2018-07-27 01:41:00 +03:00
# define MLXPLAT_CPLD_AGGR_ASIC_MASK_DEF 0x04
2016-12-14 15:05:15 +03:00
# define MLXPLAT_CPLD_AGGR_PSU_MASK_DEF 0x08
# define MLXPLAT_CPLD_AGGR_PWR_MASK_DEF 0x08
# define MLXPLAT_CPLD_AGGR_FAN_MASK_DEF 0x40
2018-07-27 01:41:00 +03:00
# define MLXPLAT_CPLD_AGGR_MASK_DEF (MLXPLAT_CPLD_AGGR_ASIC_MASK_DEF | \
MLXPLAT_CPLD_AGGR_PSU_MASK_DEF | \
2016-12-14 15:05:15 +03:00
MLXPLAT_CPLD_AGGR_FAN_MASK_DEF )
2018-07-27 01:41:00 +03:00
# define MLXPLAT_CPLD_AGGR_ASIC_MASK_NG 0x01
2018-02-02 11:45:47 +03:00
# define MLXPLAT_CPLD_AGGR_MASK_NG_DEF 0x04
2019-06-23 15:16:25 +03:00
# define MLXPLAT_CPLD_AGGR_MASK_COMEX BIT(0)
2018-07-27 01:41:00 +03:00
# define MLXPLAT_CPLD_LOW_AGGR_MASK_LOW 0xc1
2019-06-23 15:16:25 +03:00
# define MLXPLAT_CPLD_LOW_AGGR_MASK_I2C BIT(6)
2016-12-14 15:05:15 +03:00
# define MLXPLAT_CPLD_PSU_MASK GENMASK(1, 0)
# define MLXPLAT_CPLD_PWR_MASK GENMASK(1, 0)
2020-01-13 19:28:37 +03:00
# define MLXPLAT_CPLD_PSU_EXT_MASK GENMASK(3, 0)
# define MLXPLAT_CPLD_PWR_EXT_MASK GENMASK(3, 0)
2016-12-14 15:05:15 +03:00
# define MLXPLAT_CPLD_FAN_MASK GENMASK(3, 0)
2018-07-27 01:41:00 +03:00
# define MLXPLAT_CPLD_ASIC_MASK GENMASK(1, 0)
2018-02-10 02:59:32 +03:00
# define MLXPLAT_CPLD_FAN_NG_MASK GENMASK(5, 0)
2018-05-07 09:48:53 +03:00
# define MLXPLAT_CPLD_LED_LO_NIBBLE_MASK GENMASK(7, 4)
# define MLXPLAT_CPLD_LED_HI_NIBBLE_MASK GENMASK(3, 0)
2020-01-13 19:28:33 +03:00
# define MLXPLAT_CPLD_VOLTREG_UPD_MASK GENMASK(5, 4)
2020-01-13 19:28:37 +03:00
# define MLXPLAT_CPLD_I2C_CAP_BIT 0x04
# define MLXPLAT_CPLD_I2C_CAP_MASK GENMASK(5, MLXPLAT_CPLD_I2C_CAP_BIT)
2016-12-14 15:05:15 +03:00
2020-01-13 19:28:36 +03:00
/* Masks for aggregation for comex carriers */
# define MLXPLAT_CPLD_AGGR_MASK_CARRIER BIT(1)
# define MLXPLAT_CPLD_AGGR_MASK_CARR_DEF (MLXPLAT_CPLD_AGGR_ASIC_MASK_DEF | \
MLXPLAT_CPLD_AGGR_MASK_CARRIER )
# define MLXPLAT_CPLD_LOW_AGGRCX_MASK 0xc1
2018-02-14 01:09:36 +03:00
/* Default I2C parent bus number */
# define MLXPLAT_CPLD_PHYS_ADAPTER_DEF_NR 1
/* Maximum number of possible physical buses equipped on system */
# define MLXPLAT_CPLD_MAX_PHYS_ADAPTER_NUM 16
2020-01-13 19:28:36 +03:00
# define MLXPLAT_CPLD_MAX_PHYS_EXT_ADAPTER_NUM 24
2018-02-14 01:09:36 +03:00
2018-02-14 01:09:33 +03:00
/* Number of channels in group */
# define MLXPLAT_CPLD_GRP_CHNL_NUM 8
2016-09-23 00:13:42 +03:00
/* Start channel numbers */
# define MLXPLAT_CPLD_CH1 2
# define MLXPLAT_CPLD_CH2 10
2020-01-13 19:28:36 +03:00
# define MLXPLAT_CPLD_CH3 18
2016-09-23 00:13:42 +03:00
/* Number of LPC attached MUX platform devices */
2020-01-13 19:28:36 +03:00
# define MLXPLAT_CPLD_LPC_MUX_DEVS 3
2016-09-23 00:13:42 +03:00
2018-02-02 11:45:45 +03:00
/* Hotplug devices adapter numbers */
2018-02-02 11:45:46 +03:00
# define MLXPLAT_CPLD_NR_NONE -1
2018-02-02 11:45:45 +03:00
# define MLXPLAT_CPLD_PSU_DEFAULT_NR 10
2018-02-10 02:59:30 +03:00
# define MLXPLAT_CPLD_PSU_MSNXXXX_NR 4
2018-02-02 11:45:45 +03:00
# define MLXPLAT_CPLD_FAN1_DEFAULT_NR 11
# define MLXPLAT_CPLD_FAN2_DEFAULT_NR 12
# define MLXPLAT_CPLD_FAN3_DEFAULT_NR 13
# define MLXPLAT_CPLD_FAN4_DEFAULT_NR 14
2019-03-18 13:58:23 +03:00
/* Masks and default values for watchdogs */
# define MLXPLAT_CPLD_WD1_CLEAR_MASK GENMASK(7, 1)
# define MLXPLAT_CPLD_WD2_CLEAR_MASK (GENMASK(7, 0) & ~BIT(1))
# define MLXPLAT_CPLD_WD_TYPE1_TO_MASK GENMASK(7, 4)
# define MLXPLAT_CPLD_WD_TYPE2_TO_MASK 0
# define MLXPLAT_CPLD_WD_RESET_ACT_MASK GENMASK(7, 1)
# define MLXPLAT_CPLD_WD_FAN_ACT_MASK (GENMASK(7, 0) & ~BIT(4))
# define MLXPLAT_CPLD_WD_COUNT_ACT_MASK (GENMASK(7, 0) & ~BIT(7))
# define MLXPLAT_CPLD_WD_DFLT_TIMEOUT 30
# define MLXPLAT_CPLD_WD_MAX_DEVS 2
2016-09-23 00:13:42 +03:00
/* mlxplat_priv - platform private data
* @ pdev_i2c - i2c controller platform device
* @ pdev_mux - array of mux platform devices
2018-01-26 01:02:53 +03:00
* @ pdev_hotplug - hotplug platform devices
2018-05-07 09:48:53 +03:00
* @ pdev_led - led platform devices
2018-06-17 19:56:54 +03:00
* @ pdev_io_regs - register access platform devices
2018-07-27 01:40:57 +03:00
* @ pdev_fan - FAN platform devices
2019-03-18 13:58:23 +03:00
* @ pdev_wd - array of watchdog platform devices
2019-06-23 15:16:24 +03:00
* @ regmap : device register map
2016-09-23 00:13:42 +03:00
*/
struct mlxplat_priv {
struct platform_device * pdev_i2c ;
struct platform_device * pdev_mux [ MLXPLAT_CPLD_LPC_MUX_DEVS ] ;
2016-10-27 22:55:54 +03:00
struct platform_device * pdev_hotplug ;
2018-05-07 09:48:53 +03:00
struct platform_device * pdev_led ;
2018-06-17 19:56:54 +03:00
struct platform_device * pdev_io_regs ;
2018-07-27 01:40:57 +03:00
struct platform_device * pdev_fan ;
2019-03-18 13:58:23 +03:00
struct platform_device * pdev_wd [ MLXPLAT_CPLD_WD_MAX_DEVS ] ;
2019-06-23 15:16:24 +03:00
void * regmap ;
2016-09-23 00:13:42 +03:00
} ;
/* Regions for LPC I2C controller and LPC base register space */
static const struct resource mlxplat_lpc_resources [ ] = {
[ 0 ] = DEFINE_RES_NAMED ( MLXPLAT_CPLD_LPC_I2C_BASE_ADRR ,
MLXPLAT_CPLD_LPC_IO_RANGE ,
" mlxplat_cpld_lpc_i2c_ctrl " , IORESOURCE_IO ) ,
[ 1 ] = DEFINE_RES_NAMED ( MLXPLAT_CPLD_LPC_REG_BASE_ADRR ,
MLXPLAT_CPLD_LPC_IO_RANGE ,
" mlxplat_cpld_lpc_regs " ,
IORESOURCE_IO ) ,
} ;
2019-06-23 15:16:25 +03:00
/* Platform next generation systems i2c data */
static struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_i2c_ng_data = {
. cell = MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET ,
. mask = MLXPLAT_CPLD_AGGR_MASK_COMEX ,
. cell_low = MLXPLAT_CPLD_LPC_REG_AGGRCO_OFFSET ,
. mask_low = MLXPLAT_CPLD_LOW_AGGR_MASK_I2C ,
} ;
2016-09-23 00:13:42 +03:00
/* Platform default channels */
2018-02-14 01:09:33 +03:00
static const int mlxplat_default_channels [ ] [ MLXPLAT_CPLD_GRP_CHNL_NUM ] = {
2016-09-23 00:13:42 +03:00
{
MLXPLAT_CPLD_CH1 , MLXPLAT_CPLD_CH1 + 1 , MLXPLAT_CPLD_CH1 + 2 ,
MLXPLAT_CPLD_CH1 + 3 , MLXPLAT_CPLD_CH1 + 4 , MLXPLAT_CPLD_CH1 +
5 , MLXPLAT_CPLD_CH1 + 6 , MLXPLAT_CPLD_CH1 + 7
} ,
{
MLXPLAT_CPLD_CH2 , MLXPLAT_CPLD_CH2 + 1 , MLXPLAT_CPLD_CH2 + 2 ,
MLXPLAT_CPLD_CH2 + 3 , MLXPLAT_CPLD_CH2 + 4 , MLXPLAT_CPLD_CH2 +
5 , MLXPLAT_CPLD_CH2 + 6 , MLXPLAT_CPLD_CH2 + 7
} ,
} ;
/* Platform channels for MSN21xx system family */
static const int mlxplat_msn21xx_channels [ ] = { 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 } ;
/* Platform mux data */
2020-01-13 19:28:35 +03:00
static struct i2c_mux_reg_platform_data mlxplat_default_mux_data [ ] = {
2016-09-23 00:13:42 +03:00
{
. parent = 1 ,
. base_nr = MLXPLAT_CPLD_CH1 ,
. write_only = 1 ,
. reg = ( void __iomem * ) MLXPLAT_CPLD_LPC_REG1 ,
. reg_size = 1 ,
. idle_in_use = 1 ,
} ,
{
. parent = 1 ,
. base_nr = MLXPLAT_CPLD_CH2 ,
. write_only = 1 ,
. reg = ( void __iomem * ) MLXPLAT_CPLD_LPC_REG2 ,
. reg_size = 1 ,
. idle_in_use = 1 ,
} ,
} ;
2020-01-13 19:28:35 +03:00
/* Platform mux configuration variables */
static int mlxplat_max_adap_num ;
static int mlxplat_mux_num ;
static struct i2c_mux_reg_platform_data * mlxplat_mux_data ;
2020-01-13 19:28:36 +03:00
/* Platform extended mux data */
static struct i2c_mux_reg_platform_data mlxplat_extended_mux_data [ ] = {
{
. parent = 1 ,
. base_nr = MLXPLAT_CPLD_CH1 ,
. write_only = 1 ,
. reg = ( void __iomem * ) MLXPLAT_CPLD_LPC_REG1 ,
. reg_size = 1 ,
. idle_in_use = 1 ,
} ,
{
. parent = 1 ,
. base_nr = MLXPLAT_CPLD_CH2 ,
. write_only = 1 ,
. reg = ( void __iomem * ) MLXPLAT_CPLD_LPC_REG3 ,
. reg_size = 1 ,
. idle_in_use = 1 ,
} ,
{
. parent = 1 ,
. base_nr = MLXPLAT_CPLD_CH3 ,
. write_only = 1 ,
. reg = ( void __iomem * ) MLXPLAT_CPLD_LPC_REG2 ,
. reg_size = 1 ,
. idle_in_use = 1 ,
} ,
} ;
2016-10-27 22:55:54 +03:00
/* Platform hotplug devices */
2018-01-23 06:55:11 +03:00
static struct i2c_board_info mlxplat_mlxcpld_psu [ ] = {
2016-10-27 22:55:54 +03:00
{
2018-01-23 06:55:11 +03:00
I2C_BOARD_INFO ( " 24c02 " , 0x51 ) ,
2016-10-27 22:55:54 +03:00
} ,
{
2018-01-23 06:55:11 +03:00
I2C_BOARD_INFO ( " 24c02 " , 0x50 ) ,
2016-10-27 22:55:54 +03:00
} ,
} ;
2018-02-10 02:59:32 +03:00
static struct i2c_board_info mlxplat_mlxcpld_ng_psu [ ] = {
{
I2C_BOARD_INFO ( " 24c32 " , 0x51 ) ,
} ,
{
I2C_BOARD_INFO ( " 24c32 " , 0x50 ) ,
} ,
} ;
2018-01-23 06:55:11 +03:00
static struct i2c_board_info mlxplat_mlxcpld_pwr [ ] = {
2016-10-27 22:55:54 +03:00
{
2018-01-23 06:55:11 +03:00
I2C_BOARD_INFO ( " dps460 " , 0x59 ) ,
2016-10-27 22:55:54 +03:00
} ,
{
2018-01-23 06:55:11 +03:00
I2C_BOARD_INFO ( " dps460 " , 0x58 ) ,
2016-10-27 22:55:54 +03:00
} ,
} ;
2018-01-23 06:55:11 +03:00
static struct i2c_board_info mlxplat_mlxcpld_fan [ ] = {
2016-10-27 22:55:54 +03:00
{
2018-01-23 06:55:11 +03:00
I2C_BOARD_INFO ( " 24c32 " , 0x50 ) ,
2016-10-27 22:55:54 +03:00
} ,
{
2018-01-23 06:55:11 +03:00
I2C_BOARD_INFO ( " 24c32 " , 0x50 ) ,
2016-10-27 22:55:54 +03:00
} ,
{
2018-01-23 06:55:11 +03:00
I2C_BOARD_INFO ( " 24c32 " , 0x50 ) ,
2016-10-27 22:55:54 +03:00
} ,
{
2018-01-23 06:55:11 +03:00
I2C_BOARD_INFO ( " 24c32 " , 0x50 ) ,
2016-10-27 22:55:54 +03:00
} ,
} ;
2020-01-13 19:28:36 +03:00
/* Platform hotplug comex carrier system family data */
static struct mlxreg_core_data mlxplat_mlxcpld_comex_psu_items_data [ ] = {
{
. label = " psu1 " ,
. reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET ,
. mask = BIT ( 0 ) ,
. hpdev . nr = MLXPLAT_CPLD_NR_NONE ,
} ,
{
. label = " psu2 " ,
. reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET ,
. mask = BIT ( 1 ) ,
. hpdev . nr = MLXPLAT_CPLD_NR_NONE ,
} ,
} ;
2016-10-27 22:55:54 +03:00
/* Platform hotplug default data */
2018-01-23 06:55:11 +03:00
static struct mlxreg_core_data mlxplat_mlxcpld_default_psu_items_data [ ] = {
{
. label = " psu1 " ,
. reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET ,
. mask = BIT ( 0 ) ,
. hpdev . brdinfo = & mlxplat_mlxcpld_psu [ 0 ] ,
2018-02-02 11:45:45 +03:00
. hpdev . nr = MLXPLAT_CPLD_PSU_DEFAULT_NR ,
2018-01-23 06:55:11 +03:00
} ,
{
. label = " psu2 " ,
. reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET ,
. mask = BIT ( 1 ) ,
. hpdev . brdinfo = & mlxplat_mlxcpld_psu [ 1 ] ,
2018-02-02 11:45:45 +03:00
. hpdev . nr = MLXPLAT_CPLD_PSU_DEFAULT_NR ,
2018-01-23 06:55:11 +03:00
} ,
} ;
static struct mlxreg_core_data mlxplat_mlxcpld_default_pwr_items_data [ ] = {
{
. label = " pwr1 " ,
. reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET ,
. mask = BIT ( 0 ) ,
. hpdev . brdinfo = & mlxplat_mlxcpld_pwr [ 0 ] ,
2018-02-02 11:45:45 +03:00
. hpdev . nr = MLXPLAT_CPLD_PSU_DEFAULT_NR ,
2018-01-23 06:55:11 +03:00
} ,
{
. label = " pwr2 " ,
. reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET ,
. mask = BIT ( 1 ) ,
. hpdev . brdinfo = & mlxplat_mlxcpld_pwr [ 1 ] ,
2018-02-02 11:45:45 +03:00
. hpdev . nr = MLXPLAT_CPLD_PSU_DEFAULT_NR ,
2018-01-23 06:55:11 +03:00
} ,
} ;
static struct mlxreg_core_data mlxplat_mlxcpld_default_fan_items_data [ ] = {
{
. label = " fan1 " ,
. reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET ,
. mask = BIT ( 0 ) ,
. hpdev . brdinfo = & mlxplat_mlxcpld_fan [ 0 ] ,
2018-02-02 11:45:45 +03:00
. hpdev . nr = MLXPLAT_CPLD_FAN1_DEFAULT_NR ,
2018-01-23 06:55:11 +03:00
} ,
{
. label = " fan2 " ,
. reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET ,
. mask = BIT ( 1 ) ,
. hpdev . brdinfo = & mlxplat_mlxcpld_fan [ 1 ] ,
2018-02-02 11:45:45 +03:00
. hpdev . nr = MLXPLAT_CPLD_FAN2_DEFAULT_NR ,
2018-01-23 06:55:11 +03:00
} ,
{
. label = " fan3 " ,
. reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET ,
. mask = BIT ( 2 ) ,
. hpdev . brdinfo = & mlxplat_mlxcpld_fan [ 2 ] ,
2018-02-02 11:45:45 +03:00
. hpdev . nr = MLXPLAT_CPLD_FAN3_DEFAULT_NR ,
2018-01-23 06:55:11 +03:00
} ,
{
. label = " fan4 " ,
. reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET ,
. mask = BIT ( 3 ) ,
. hpdev . brdinfo = & mlxplat_mlxcpld_fan [ 3 ] ,
2018-02-02 11:45:45 +03:00
. hpdev . nr = MLXPLAT_CPLD_FAN4_DEFAULT_NR ,
2018-01-23 06:55:11 +03:00
} ,
} ;
2018-07-27 01:41:00 +03:00
static struct mlxreg_core_data mlxplat_mlxcpld_default_asic_items_data [ ] = {
{
. label = " asic1 " ,
. reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET ,
. mask = MLXPLAT_CPLD_ASIC_MASK ,
. hpdev . nr = MLXPLAT_CPLD_NR_NONE ,
} ,
} ;
2018-01-23 06:55:11 +03:00
static struct mlxreg_core_item mlxplat_mlxcpld_default_items [ ] = {
{
. data = mlxplat_mlxcpld_default_psu_items_data ,
. aggr_mask = MLXPLAT_CPLD_AGGR_PSU_MASK_DEF ,
. reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET ,
. mask = MLXPLAT_CPLD_PSU_MASK ,
. count = ARRAY_SIZE ( mlxplat_mlxcpld_psu ) ,
. inversed = 1 ,
. health = false ,
} ,
{
. data = mlxplat_mlxcpld_default_pwr_items_data ,
. aggr_mask = MLXPLAT_CPLD_AGGR_PWR_MASK_DEF ,
. reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET ,
. mask = MLXPLAT_CPLD_PWR_MASK ,
. count = ARRAY_SIZE ( mlxplat_mlxcpld_pwr ) ,
. inversed = 0 ,
. health = false ,
} ,
{
. data = mlxplat_mlxcpld_default_fan_items_data ,
. aggr_mask = MLXPLAT_CPLD_AGGR_FAN_MASK_DEF ,
. reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET ,
. mask = MLXPLAT_CPLD_FAN_MASK ,
. count = ARRAY_SIZE ( mlxplat_mlxcpld_fan ) ,
. inversed = 1 ,
. health = false ,
} ,
2018-07-27 01:41:00 +03:00
{
. data = mlxplat_mlxcpld_default_asic_items_data ,
. aggr_mask = MLXPLAT_CPLD_AGGR_ASIC_MASK_DEF ,
. reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET ,
. mask = MLXPLAT_CPLD_ASIC_MASK ,
. count = ARRAY_SIZE ( mlxplat_mlxcpld_default_asic_items_data ) ,
. inversed = 0 ,
. health = true ,
} ,
2018-01-23 06:55:11 +03:00
} ;
2020-01-13 19:28:36 +03:00
static struct mlxreg_core_item mlxplat_mlxcpld_comex_items [ ] = {
{
. data = mlxplat_mlxcpld_comex_psu_items_data ,
. aggr_mask = MLXPLAT_CPLD_AGGR_MASK_CARRIER ,
. reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET ,
. mask = MLXPLAT_CPLD_PSU_MASK ,
. count = ARRAY_SIZE ( mlxplat_mlxcpld_psu ) ,
. inversed = 1 ,
. health = false ,
} ,
{
. data = mlxplat_mlxcpld_default_pwr_items_data ,
. aggr_mask = MLXPLAT_CPLD_AGGR_MASK_CARRIER ,
. reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET ,
. mask = MLXPLAT_CPLD_PWR_MASK ,
. count = ARRAY_SIZE ( mlxplat_mlxcpld_pwr ) ,
. inversed = 0 ,
. health = false ,
} ,
{
. data = mlxplat_mlxcpld_default_fan_items_data ,
. aggr_mask = MLXPLAT_CPLD_AGGR_MASK_CARRIER ,
. reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET ,
. mask = MLXPLAT_CPLD_FAN_MASK ,
. count = ARRAY_SIZE ( mlxplat_mlxcpld_fan ) ,
. inversed = 1 ,
. health = false ,
} ,
{
. data = mlxplat_mlxcpld_default_asic_items_data ,
. aggr_mask = MLXPLAT_CPLD_AGGR_ASIC_MASK_DEF ,
. reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET ,
. mask = MLXPLAT_CPLD_ASIC_MASK ,
. count = ARRAY_SIZE ( mlxplat_mlxcpld_default_asic_items_data ) ,
. inversed = 0 ,
. health = true ,
} ,
} ;
2016-10-27 22:55:54 +03:00
static
2018-01-23 06:55:11 +03:00
struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_default_data = {
. items = mlxplat_mlxcpld_default_items ,
. counter = ARRAY_SIZE ( mlxplat_mlxcpld_default_items ) ,
. cell = MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET ,
. mask = MLXPLAT_CPLD_AGGR_MASK_DEF ,
2018-07-27 01:41:00 +03:00
. cell_low = MLXPLAT_CPLD_LPC_REG_AGGRLO_OFFSET ,
. mask_low = MLXPLAT_CPLD_LOW_AGGR_MASK_LOW ,
2016-10-27 22:55:54 +03:00
} ;
2020-01-13 19:28:36 +03:00
static
struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_comex_data = {
. items = mlxplat_mlxcpld_comex_items ,
. counter = ARRAY_SIZE ( mlxplat_mlxcpld_comex_items ) ,
. cell = MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET ,
. mask = MLXPLAT_CPLD_AGGR_MASK_CARR_DEF ,
. cell_low = MLXPLAT_CPLD_LPC_REG_AGGRCX_OFFSET ,
. mask_low = MLXPLAT_CPLD_LOW_AGGRCX_MASK ,
} ;
2018-02-02 11:45:47 +03:00
static struct mlxreg_core_data mlxplat_mlxcpld_msn21xx_pwr_items_data [ ] = {
{
. label = " pwr1 " ,
. reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET ,
. mask = BIT ( 0 ) ,
. hpdev . nr = MLXPLAT_CPLD_NR_NONE ,
} ,
{
. label = " pwr2 " ,
. reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET ,
. mask = BIT ( 1 ) ,
. hpdev . nr = MLXPLAT_CPLD_NR_NONE ,
} ,
} ;
2016-10-27 22:55:54 +03:00
/* Platform hotplug MSN21xx system family data */
2018-01-23 06:55:11 +03:00
static struct mlxreg_core_item mlxplat_mlxcpld_msn21xx_items [ ] = {
{
2018-02-02 11:45:47 +03:00
. data = mlxplat_mlxcpld_msn21xx_pwr_items_data ,
2018-01-23 06:55:11 +03:00
. aggr_mask = MLXPLAT_CPLD_AGGR_PWR_MASK_DEF ,
. reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET ,
. mask = MLXPLAT_CPLD_PWR_MASK ,
2018-02-02 11:45:47 +03:00
. count = ARRAY_SIZE ( mlxplat_mlxcpld_msn21xx_pwr_items_data ) ,
2018-01-23 06:55:11 +03:00
. inversed = 0 ,
. health = false ,
} ,
2018-07-27 01:41:00 +03:00
{
. data = mlxplat_mlxcpld_default_asic_items_data ,
. aggr_mask = MLXPLAT_CPLD_AGGR_ASIC_MASK_DEF ,
. reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET ,
. mask = MLXPLAT_CPLD_ASIC_MASK ,
. count = ARRAY_SIZE ( mlxplat_mlxcpld_default_asic_items_data ) ,
. inversed = 0 ,
. health = true ,
} ,
2018-01-23 06:55:11 +03:00
} ;
2016-10-27 22:55:54 +03:00
static
2018-01-23 06:55:11 +03:00
struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_msn21xx_data = {
. items = mlxplat_mlxcpld_msn21xx_items ,
. counter = ARRAY_SIZE ( mlxplat_mlxcpld_msn21xx_items ) ,
. cell = MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET ,
. mask = MLXPLAT_CPLD_AGGR_MASK_DEF ,
2018-02-02 11:45:47 +03:00
. cell_low = MLXPLAT_CPLD_LPC_REG_AGGRLO_OFFSET ,
. mask_low = MLXPLAT_CPLD_LOW_AGGR_MASK_LOW ,
2018-01-23 06:55:11 +03:00
} ;
2018-02-10 02:59:30 +03:00
/* Platform hotplug msn274x system family data */
static struct mlxreg_core_data mlxplat_mlxcpld_msn274x_psu_items_data [ ] = {
{
. label = " psu1 " ,
. reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET ,
. mask = BIT ( 0 ) ,
. hpdev . brdinfo = & mlxplat_mlxcpld_psu [ 0 ] ,
. hpdev . nr = MLXPLAT_CPLD_PSU_MSNXXXX_NR ,
} ,
{
. label = " psu2 " ,
. reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET ,
. mask = BIT ( 1 ) ,
. hpdev . brdinfo = & mlxplat_mlxcpld_psu [ 1 ] ,
. hpdev . nr = MLXPLAT_CPLD_PSU_MSNXXXX_NR ,
} ,
} ;
static struct mlxreg_core_data mlxplat_mlxcpld_default_ng_pwr_items_data [ ] = {
{
. label = " pwr1 " ,
. reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET ,
. mask = BIT ( 0 ) ,
. hpdev . brdinfo = & mlxplat_mlxcpld_pwr [ 0 ] ,
. hpdev . nr = MLXPLAT_CPLD_PSU_MSNXXXX_NR ,
} ,
{
. label = " pwr2 " ,
. reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET ,
. mask = BIT ( 1 ) ,
. hpdev . brdinfo = & mlxplat_mlxcpld_pwr [ 1 ] ,
. hpdev . nr = MLXPLAT_CPLD_PSU_MSNXXXX_NR ,
} ,
} ;
static struct mlxreg_core_data mlxplat_mlxcpld_msn274x_fan_items_data [ ] = {
{
. label = " fan1 " ,
. reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET ,
. mask = BIT ( 0 ) ,
. hpdev . nr = MLXPLAT_CPLD_NR_NONE ,
} ,
{
. label = " fan2 " ,
. reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET ,
. mask = BIT ( 1 ) ,
. hpdev . nr = MLXPLAT_CPLD_NR_NONE ,
} ,
{
. label = " fan3 " ,
. reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET ,
. mask = BIT ( 2 ) ,
. hpdev . nr = MLXPLAT_CPLD_NR_NONE ,
} ,
{
. label = " fan4 " ,
. reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET ,
. mask = BIT ( 3 ) ,
. hpdev . nr = MLXPLAT_CPLD_NR_NONE ,
} ,
} ;
static struct mlxreg_core_item mlxplat_mlxcpld_msn274x_items [ ] = {
{
. data = mlxplat_mlxcpld_msn274x_psu_items_data ,
. aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF ,
. reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET ,
. mask = MLXPLAT_CPLD_PSU_MASK ,
. count = ARRAY_SIZE ( mlxplat_mlxcpld_msn274x_psu_items_data ) ,
. inversed = 1 ,
. health = false ,
} ,
{
. data = mlxplat_mlxcpld_default_ng_pwr_items_data ,
. aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF ,
. reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET ,
. mask = MLXPLAT_CPLD_PWR_MASK ,
. count = ARRAY_SIZE ( mlxplat_mlxcpld_default_ng_pwr_items_data ) ,
. inversed = 0 ,
. health = false ,
} ,
{
. data = mlxplat_mlxcpld_msn274x_fan_items_data ,
. aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF ,
. reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET ,
. mask = MLXPLAT_CPLD_FAN_MASK ,
. count = ARRAY_SIZE ( mlxplat_mlxcpld_msn274x_fan_items_data ) ,
. inversed = 1 ,
. health = false ,
} ,
2018-07-27 01:41:00 +03:00
{
. data = mlxplat_mlxcpld_default_asic_items_data ,
. aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF ,
. reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET ,
. mask = MLXPLAT_CPLD_ASIC_MASK ,
. count = ARRAY_SIZE ( mlxplat_mlxcpld_default_asic_items_data ) ,
. inversed = 0 ,
. health = true ,
} ,
2018-02-10 02:59:30 +03:00
} ;
static
struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_msn274x_data = {
. items = mlxplat_mlxcpld_msn274x_items ,
. counter = ARRAY_SIZE ( mlxplat_mlxcpld_msn274x_items ) ,
. cell = MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET ,
. mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF ,
. cell_low = MLXPLAT_CPLD_LPC_REG_AGGRLO_OFFSET ,
. mask_low = MLXPLAT_CPLD_LOW_AGGR_MASK_LOW ,
} ;
2018-02-10 02:59:31 +03:00
/* Platform hotplug MSN201x system family data */
static struct mlxreg_core_data mlxplat_mlxcpld_msn201x_pwr_items_data [ ] = {
{
. label = " pwr1 " ,
. reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET ,
. mask = BIT ( 0 ) ,
. hpdev . nr = MLXPLAT_CPLD_NR_NONE ,
} ,
{
. label = " pwr2 " ,
. reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET ,
. mask = BIT ( 1 ) ,
. hpdev . nr = MLXPLAT_CPLD_NR_NONE ,
} ,
} ;
static struct mlxreg_core_item mlxplat_mlxcpld_msn201x_items [ ] = {
{
. data = mlxplat_mlxcpld_msn201x_pwr_items_data ,
. aggr_mask = MLXPLAT_CPLD_AGGR_PWR_MASK_DEF ,
. reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET ,
. mask = MLXPLAT_CPLD_PWR_MASK ,
. count = ARRAY_SIZE ( mlxplat_mlxcpld_msn201x_pwr_items_data ) ,
. inversed = 0 ,
. health = false ,
} ,
2018-07-27 01:41:00 +03:00
{
. data = mlxplat_mlxcpld_default_asic_items_data ,
. aggr_mask = MLXPLAT_CPLD_AGGR_ASIC_MASK_DEF ,
. reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET ,
. mask = MLXPLAT_CPLD_ASIC_MASK ,
. count = ARRAY_SIZE ( mlxplat_mlxcpld_default_asic_items_data ) ,
. inversed = 0 ,
. health = true ,
} ,
2018-02-10 02:59:31 +03:00
} ;
static
struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_msn201x_data = {
2018-09-26 08:21:15 +03:00
. items = mlxplat_mlxcpld_msn201x_items ,
2018-02-10 02:59:31 +03:00
. counter = ARRAY_SIZE ( mlxplat_mlxcpld_msn201x_items ) ,
. cell = MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET ,
. mask = MLXPLAT_CPLD_AGGR_MASK_DEF ,
. cell_low = MLXPLAT_CPLD_LPC_REG_AGGRLO_OFFSET ,
. mask_low = MLXPLAT_CPLD_LOW_AGGR_MASK_LOW ,
} ;
2018-02-10 02:59:32 +03:00
/* Platform hotplug next generation system family data */
static struct mlxreg_core_data mlxplat_mlxcpld_default_ng_psu_items_data [ ] = {
{
. label = " psu1 " ,
. reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET ,
. mask = BIT ( 0 ) ,
. hpdev . brdinfo = & mlxplat_mlxcpld_ng_psu [ 0 ] ,
. hpdev . nr = MLXPLAT_CPLD_PSU_MSNXXXX_NR ,
} ,
{
. label = " psu2 " ,
. reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET ,
. mask = BIT ( 1 ) ,
. hpdev . brdinfo = & mlxplat_mlxcpld_ng_psu [ 1 ] ,
. hpdev . nr = MLXPLAT_CPLD_PSU_MSNXXXX_NR ,
} ,
} ;
static struct mlxreg_core_data mlxplat_mlxcpld_default_ng_fan_items_data [ ] = {
{
. label = " fan1 " ,
. reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET ,
. mask = BIT ( 0 ) ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET ,
. bit = BIT ( 0 ) ,
2018-02-10 02:59:32 +03:00
. hpdev . nr = MLXPLAT_CPLD_NR_NONE ,
} ,
{
. label = " fan2 " ,
. reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET ,
. mask = BIT ( 1 ) ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET ,
. bit = BIT ( 1 ) ,
2018-02-10 02:59:32 +03:00
. hpdev . nr = MLXPLAT_CPLD_NR_NONE ,
} ,
{
. label = " fan3 " ,
. reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET ,
. mask = BIT ( 2 ) ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET ,
. bit = BIT ( 2 ) ,
2018-02-10 02:59:32 +03:00
. hpdev . nr = MLXPLAT_CPLD_NR_NONE ,
} ,
{
. label = " fan4 " ,
. reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET ,
. mask = BIT ( 3 ) ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET ,
. bit = BIT ( 3 ) ,
2018-02-10 02:59:32 +03:00
. hpdev . nr = MLXPLAT_CPLD_NR_NONE ,
} ,
{
. label = " fan5 " ,
. reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET ,
. mask = BIT ( 4 ) ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET ,
. bit = BIT ( 4 ) ,
2018-02-10 02:59:32 +03:00
. hpdev . nr = MLXPLAT_CPLD_NR_NONE ,
} ,
{
. label = " fan6 " ,
. reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET ,
. mask = BIT ( 5 ) ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET ,
. bit = BIT ( 5 ) ,
2018-02-10 02:59:32 +03:00
. hpdev . nr = MLXPLAT_CPLD_NR_NONE ,
} ,
} ;
static struct mlxreg_core_item mlxplat_mlxcpld_default_ng_items [ ] = {
{
. data = mlxplat_mlxcpld_default_ng_psu_items_data ,
. aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF ,
. reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET ,
. mask = MLXPLAT_CPLD_PSU_MASK ,
. count = ARRAY_SIZE ( mlxplat_mlxcpld_default_ng_psu_items_data ) ,
. inversed = 1 ,
. health = false ,
} ,
{
. data = mlxplat_mlxcpld_default_ng_pwr_items_data ,
. aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF ,
. reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET ,
. mask = MLXPLAT_CPLD_PWR_MASK ,
. count = ARRAY_SIZE ( mlxplat_mlxcpld_default_ng_pwr_items_data ) ,
. inversed = 0 ,
. health = false ,
} ,
{
. data = mlxplat_mlxcpld_default_ng_fan_items_data ,
. aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF ,
. reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET ,
. mask = MLXPLAT_CPLD_FAN_NG_MASK ,
. count = ARRAY_SIZE ( mlxplat_mlxcpld_default_ng_fan_items_data ) ,
. inversed = 1 ,
. health = false ,
} ,
2018-07-27 01:41:00 +03:00
{
. data = mlxplat_mlxcpld_default_asic_items_data ,
. aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF ,
. reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET ,
. mask = MLXPLAT_CPLD_ASIC_MASK ,
. count = ARRAY_SIZE ( mlxplat_mlxcpld_default_asic_items_data ) ,
. inversed = 0 ,
. health = true ,
} ,
2018-02-10 02:59:32 +03:00
} ;
static
struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_default_ng_data = {
. items = mlxplat_mlxcpld_default_ng_items ,
. counter = ARRAY_SIZE ( mlxplat_mlxcpld_default_ng_items ) ,
. cell = MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET ,
2019-06-23 15:16:25 +03:00
. mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF | MLXPLAT_CPLD_AGGR_MASK_COMEX ,
2018-02-10 02:59:32 +03:00
. cell_low = MLXPLAT_CPLD_LPC_REG_AGGRLO_OFFSET ,
. mask_low = MLXPLAT_CPLD_LOW_AGGR_MASK_LOW ,
} ;
2018-05-07 09:48:53 +03:00
/* Platform led default data */
static struct mlxreg_core_data mlxplat_mlxcpld_default_led_data [ ] = {
{
. label = " status:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
} ,
{
. label = " status:red " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK
} ,
{
. label = " psu:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
} ,
{
. label = " psu:red " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
} ,
{
. label = " fan1:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
} ,
{
. label = " fan1:red " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
} ,
{
. label = " fan2:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
} ,
{
. label = " fan2:red " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
} ,
{
. label = " fan3:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
} ,
{
. label = " fan3:red " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
} ,
{
. label = " fan4:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
} ,
{
. label = " fan4:red " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
} ,
} ;
static struct mlxreg_core_platform_data mlxplat_default_led_data = {
. data = mlxplat_mlxcpld_default_led_data ,
. counter = ARRAY_SIZE ( mlxplat_mlxcpld_default_led_data ) ,
} ;
/* Platform led MSN21xx system family data */
static struct mlxreg_core_data mlxplat_mlxcpld_msn21xx_led_data [ ] = {
{
. label = " status:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
} ,
{
. label = " status:red " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK
} ,
{
. label = " fan:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
} ,
{
. label = " fan:red " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
} ,
{
. label = " psu1:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED4_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
} ,
{
. label = " psu1:red " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED4_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
} ,
{
. label = " psu2:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED4_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
} ,
{
. label = " psu2:red " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED4_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
} ,
{
. label = " uid:blue " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED5_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
} ,
} ;
static struct mlxreg_core_platform_data mlxplat_msn21xx_led_data = {
. data = mlxplat_mlxcpld_msn21xx_led_data ,
. counter = ARRAY_SIZE ( mlxplat_mlxcpld_msn21xx_led_data ) ,
} ;
/* Platform led for default data for 200GbE systems */
static struct mlxreg_core_data mlxplat_mlxcpld_default_ng_led_data [ ] = {
{
. label = " status:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
} ,
{
. label = " status:orange " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK
} ,
{
. label = " psu:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
} ,
{
. label = " psu:orange " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
} ,
{
. label = " fan1:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET ,
. bit = BIT ( 0 ) ,
2018-05-07 09:48:53 +03:00
} ,
{
. label = " fan1:orange " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET ,
. bit = BIT ( 0 ) ,
2018-05-07 09:48:53 +03:00
} ,
{
. label = " fan2:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET ,
. bit = BIT ( 1 ) ,
2018-05-07 09:48:53 +03:00
} ,
{
. label = " fan2:orange " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET ,
. bit = BIT ( 1 ) ,
2018-05-07 09:48:53 +03:00
} ,
{
. label = " fan3:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET ,
. bit = BIT ( 2 ) ,
2018-05-07 09:48:53 +03:00
} ,
{
. label = " fan3:orange " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET ,
. bit = BIT ( 2 ) ,
2018-05-07 09:48:53 +03:00
} ,
{
. label = " fan4:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET ,
. bit = BIT ( 3 ) ,
2018-05-07 09:48:53 +03:00
} ,
{
. label = " fan4:orange " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET ,
. bit = BIT ( 3 ) ,
2018-05-07 09:48:53 +03:00
} ,
{
. label = " fan5:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED4_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET ,
. bit = BIT ( 4 ) ,
2018-05-07 09:48:53 +03:00
} ,
{
. label = " fan5:orange " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED4_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET ,
. bit = BIT ( 4 ) ,
2018-05-07 09:48:53 +03:00
} ,
{
. label = " fan6:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED4_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET ,
. bit = BIT ( 5 ) ,
2018-05-07 09:48:53 +03:00
} ,
{
. label = " fan6:orange " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED4_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET ,
. bit = BIT ( 5 ) ,
2018-05-07 09:48:53 +03:00
} ,
2019-02-26 11:20:33 +03:00
{
. label = " uid:blue " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED5_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
} ,
2018-05-07 09:48:53 +03:00
} ;
static struct mlxreg_core_platform_data mlxplat_default_ng_led_data = {
. data = mlxplat_mlxcpld_default_ng_led_data ,
. counter = ARRAY_SIZE ( mlxplat_mlxcpld_default_ng_led_data ) ,
} ;
2020-01-13 19:28:36 +03:00
/* Platform led for Comex based 100GbE systems */
static struct mlxreg_core_data mlxplat_mlxcpld_comex_100G_led_data [ ] = {
{
. label = " status:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
} ,
{
. label = " status:red " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK
} ,
{
. label = " psu:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
} ,
{
. label = " psu:red " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
} ,
{
. label = " fan1:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
} ,
{
. label = " fan1:red " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
} ,
{
. label = " fan2:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
} ,
{
. label = " fan2:red " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
} ,
{
. label = " fan3:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
} ,
{
. label = " fan3:red " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
} ,
{
. label = " fan4:green " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
} ,
{
. label = " fan4:red " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET ,
. mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK ,
} ,
{
. label = " uid:blue " ,
. reg = MLXPLAT_CPLD_LPC_REG_LED5_OFFSET ,
. mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK ,
} ,
} ;
static struct mlxreg_core_platform_data mlxplat_comex_100G_led_data = {
. data = mlxplat_mlxcpld_comex_100G_led_data ,
. counter = ARRAY_SIZE ( mlxplat_mlxcpld_comex_100G_led_data ) ,
} ;
2018-06-17 19:56:54 +03:00
/* Platform register access default */
static struct mlxreg_core_data mlxplat_mlxcpld_default_regs_io_data [ ] = {
{
. label = " cpld1_version " ,
. reg = MLXPLAT_CPLD_LPC_REG_CPLD1_VER_OFFSET ,
. bit = GENMASK ( 7 , 0 ) ,
. mode = 0444 ,
} ,
{
. label = " cpld2_version " ,
. reg = MLXPLAT_CPLD_LPC_REG_CPLD2_VER_OFFSET ,
. bit = GENMASK ( 7 , 0 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_long_pb " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 0 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_short_pb " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 1 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_aux_pwr_or_ref " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 2 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_main_pwr_fail " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 3 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_sw_reset " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 4 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_fw_reset " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 5 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_hotswap_or_wd " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 6 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_asic_thermal " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 7 ) ,
. mode = 0444 ,
} ,
{
. label = " psu1_on " ,
. reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 0 ) ,
. mode = 0200 ,
} ,
{
. label = " psu2_on " ,
. reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 1 ) ,
. mode = 0200 ,
} ,
{
. label = " pwr_cycle " ,
. reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 2 ) ,
. mode = 0200 ,
} ,
{
. label = " pwr_down " ,
. reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 3 ) ,
. mode = 0200 ,
} ,
{
. label = " select_iio " ,
. reg = MLXPLAT_CPLD_LPC_REG_GP2_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 6 ) ,
. mode = 0644 ,
} ,
{
. label = " asic_health " ,
. reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET ,
2018-07-27 01:41:00 +03:00
. mask = MLXPLAT_CPLD_ASIC_MASK ,
2018-06-17 19:56:54 +03:00
. bit = 1 ,
. mode = 0444 ,
} ,
} ;
static struct mlxreg_core_platform_data mlxplat_default_regs_io_data = {
. data = mlxplat_mlxcpld_default_regs_io_data ,
. counter = ARRAY_SIZE ( mlxplat_mlxcpld_default_regs_io_data ) ,
} ;
2018-05-07 09:48:53 +03:00
2018-07-27 01:41:03 +03:00
/* Platform register access MSN21xx, MSN201x, MSN274x systems families data */
2018-07-27 01:41:01 +03:00
static struct mlxreg_core_data mlxplat_mlxcpld_msn21xx_regs_io_data [ ] = {
{
. label = " cpld1_version " ,
. reg = MLXPLAT_CPLD_LPC_REG_CPLD1_VER_OFFSET ,
. bit = GENMASK ( 7 , 0 ) ,
. mode = 0444 ,
} ,
{
. label = " cpld2_version " ,
. reg = MLXPLAT_CPLD_LPC_REG_CPLD2_VER_OFFSET ,
. bit = GENMASK ( 7 , 0 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_long_pb " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 0 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_short_pb " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 1 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_aux_pwr_or_ref " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 2 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_sw_reset " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 3 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_main_pwr_fail " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 4 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_asic_thermal " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 5 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_hotswap_or_halt " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 6 ) ,
. mode = 0444 ,
} ,
2019-06-23 15:16:28 +03:00
{
. label = " reset_sff_wd " ,
. reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 6 ) ,
. mode = 0444 ,
} ,
2018-07-27 01:41:01 +03:00
{
. label = " psu1_on " ,
. reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 0 ) ,
. mode = 0200 ,
} ,
{
. label = " psu2_on " ,
. reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 1 ) ,
. mode = 0200 ,
} ,
{
. label = " pwr_cycle " ,
. reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 2 ) ,
. mode = 0200 ,
} ,
{
. label = " pwr_down " ,
. reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 3 ) ,
. mode = 0200 ,
} ,
2020-01-13 19:28:33 +03:00
{
. label = " select_iio " ,
. reg = MLXPLAT_CPLD_LPC_REG_GP2_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 6 ) ,
. mode = 0644 ,
} ,
2018-07-27 01:41:01 +03:00
{
. label = " asic_health " ,
. reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET ,
. mask = MLXPLAT_CPLD_ASIC_MASK ,
. bit = 1 ,
. mode = 0444 ,
} ,
} ;
static struct mlxreg_core_platform_data mlxplat_msn21xx_regs_io_data = {
. data = mlxplat_mlxcpld_msn21xx_regs_io_data ,
. counter = ARRAY_SIZE ( mlxplat_mlxcpld_msn21xx_regs_io_data ) ,
} ;
2018-11-15 20:26:58 +03:00
/* Platform register access for next generation systems families data */
static struct mlxreg_core_data mlxplat_mlxcpld_default_ng_regs_io_data [ ] = {
{
. label = " cpld1_version " ,
. reg = MLXPLAT_CPLD_LPC_REG_CPLD1_VER_OFFSET ,
. bit = GENMASK ( 7 , 0 ) ,
. mode = 0444 ,
} ,
{
. label = " cpld2_version " ,
. reg = MLXPLAT_CPLD_LPC_REG_CPLD2_VER_OFFSET ,
. bit = GENMASK ( 7 , 0 ) ,
. mode = 0444 ,
} ,
{
. label = " cpld3_version " ,
. reg = MLXPLAT_CPLD_LPC_REG_CPLD3_VER_OFFSET ,
. bit = GENMASK ( 7 , 0 ) ,
. mode = 0444 ,
} ,
2019-02-26 11:20:32 +03:00
{
. label = " cpld4_version " ,
. reg = MLXPLAT_CPLD_LPC_REG_CPLD4_VER_OFFSET ,
. bit = GENMASK ( 7 , 0 ) ,
. mode = 0444 ,
} ,
2018-11-15 20:26:58 +03:00
{
. label = " reset_long_pb " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 0 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_short_pb " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 1 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_aux_pwr_or_ref " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 2 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_from_comex " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 4 ) ,
. mode = 0444 ,
} ,
2019-06-23 15:16:28 +03:00
{
. label = " reset_from_asic " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 5 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_swb_wd " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 6 ) ,
. mode = 0444 ,
} ,
2018-11-15 20:26:58 +03:00
{
. label = " reset_asic_thermal " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 7 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_comex_pwr_fail " ,
. reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 3 ) ,
. mode = 0444 ,
} ,
2020-01-13 19:28:33 +03:00
{
. label = " reset_platform " ,
. reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 4 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_soc " ,
. reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 5 ) ,
. mode = 0444 ,
} ,
2019-06-23 15:16:28 +03:00
{
. label = " reset_comex_wd " ,
. reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 6 ) ,
. mode = 0444 ,
} ,
2018-11-15 20:26:58 +03:00
{
. label = " reset_voltmon_upgrade_fail " ,
. reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 0 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_system " ,
. reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 1 ) ,
. mode = 0444 ,
} ,
2020-01-13 19:28:33 +03:00
{
. label = " reset_sw_pwr_off " ,
. reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 2 ) ,
. mode = 0444 ,
} ,
2019-06-23 15:16:28 +03:00
{
. label = " reset_comex_thermal " ,
. reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 3 ) ,
. mode = 0444 ,
} ,
{
. label = " reset_reload_bios " ,
. reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 5 ) ,
. mode = 0444 ,
} ,
2020-01-13 19:28:33 +03:00
{
. label = " reset_ac_pwr_fail " ,
. reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 6 ) ,
. mode = 0444 ,
} ,
2018-11-15 20:26:58 +03:00
{
. label = " psu1_on " ,
. reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 0 ) ,
. mode = 0200 ,
} ,
{
. label = " psu2_on " ,
. reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 1 ) ,
. mode = 0200 ,
} ,
{
. label = " pwr_cycle " ,
. reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 2 ) ,
. mode = 0200 ,
} ,
{
. label = " pwr_down " ,
. reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 3 ) ,
. mode = 0200 ,
} ,
{
. label = " jtag_enable " ,
. reg = MLXPLAT_CPLD_LPC_REG_GP2_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 4 ) ,
. mode = 0644 ,
} ,
{
. label = " asic_health " ,
. reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET ,
. mask = MLXPLAT_CPLD_ASIC_MASK ,
. bit = 1 ,
. mode = 0444 ,
} ,
2018-12-13 02:59:11 +03:00
{
. label = " fan_dir " ,
. reg = MLXPLAT_CPLD_LPC_REG_FAN_DIRECTION ,
. bit = GENMASK ( 7 , 0 ) ,
2019-02-26 11:20:34 +03:00
. mode = 0444 ,
2018-12-13 02:59:11 +03:00
} ,
2020-01-13 19:28:33 +03:00
{
. label = " voltreg_update_status " ,
. reg = MLXPLAT_CPLD_LPC_REG_GP0_RO_OFFSET ,
. mask = MLXPLAT_CPLD_VOLTREG_UPD_MASK ,
. bit = 5 ,
. mode = 0444 ,
} ,
{
. label = " vpd_wp " ,
. reg = MLXPLAT_CPLD_LPC_REG_GP0_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 3 ) ,
. mode = 0644 ,
} ,
{
. label = " pcie_asic_reset_dis " ,
. reg = MLXPLAT_CPLD_LPC_REG_GP0_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 4 ) ,
. mode = 0644 ,
} ,
{
. label = " config1 " ,
. reg = MLXPLAT_CPLD_LPC_REG_CONFIG1_OFFSET ,
. bit = GENMASK ( 7 , 0 ) ,
. mode = 0444 ,
} ,
{
. label = " config2 " ,
. reg = MLXPLAT_CPLD_LPC_REG_CONFIG2_OFFSET ,
. bit = GENMASK ( 7 , 0 ) ,
. mode = 0444 ,
} ,
{
. label = " ufm_version " ,
. reg = MLXPLAT_CPLD_LPC_REG_UFM_VERSION_OFFSET ,
. bit = GENMASK ( 7 , 0 ) ,
. mode = 0444 ,
} ,
2018-11-15 20:26:58 +03:00
} ;
static struct mlxreg_core_platform_data mlxplat_default_ng_regs_io_data = {
. data = mlxplat_mlxcpld_default_ng_regs_io_data ,
. counter = ARRAY_SIZE ( mlxplat_mlxcpld_default_ng_regs_io_data ) ,
} ;
2018-07-27 01:40:57 +03:00
/* Platform FAN default */
static struct mlxreg_core_data mlxplat_mlxcpld_default_fan_data [ ] = {
{
. label = " pwm1 " ,
. reg = MLXPLAT_CPLD_LPC_REG_PWM1_OFFSET ,
} ,
{
. label = " tacho1 " ,
. reg = MLXPLAT_CPLD_LPC_REG_TACHO1_OFFSET ,
. mask = GENMASK ( 7 , 0 ) ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET ,
. bit = BIT ( 0 ) ,
2018-07-27 01:40:57 +03:00
} ,
{
. label = " tacho2 " ,
. reg = MLXPLAT_CPLD_LPC_REG_TACHO2_OFFSET ,
. mask = GENMASK ( 7 , 0 ) ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET ,
. bit = BIT ( 1 ) ,
2018-07-27 01:40:57 +03:00
} ,
{
. label = " tacho3 " ,
. reg = MLXPLAT_CPLD_LPC_REG_TACHO3_OFFSET ,
. mask = GENMASK ( 7 , 0 ) ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET ,
. bit = BIT ( 2 ) ,
2018-07-27 01:40:57 +03:00
} ,
{
. label = " tacho4 " ,
. reg = MLXPLAT_CPLD_LPC_REG_TACHO4_OFFSET ,
. mask = GENMASK ( 7 , 0 ) ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET ,
. bit = BIT ( 3 ) ,
2018-07-27 01:40:57 +03:00
} ,
{
. label = " tacho5 " ,
. reg = MLXPLAT_CPLD_LPC_REG_TACHO5_OFFSET ,
. mask = GENMASK ( 7 , 0 ) ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET ,
. bit = BIT ( 4 ) ,
2018-07-27 01:40:57 +03:00
} ,
{
. label = " tacho6 " ,
. reg = MLXPLAT_CPLD_LPC_REG_TACHO6_OFFSET ,
. mask = GENMASK ( 7 , 0 ) ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET ,
. bit = BIT ( 5 ) ,
2018-07-27 01:40:57 +03:00
} ,
{
. label = " tacho7 " ,
. reg = MLXPLAT_CPLD_LPC_REG_TACHO7_OFFSET ,
. mask = GENMASK ( 7 , 0 ) ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET ,
. bit = BIT ( 6 ) ,
2018-07-27 01:40:57 +03:00
} ,
{
. label = " tacho8 " ,
. reg = MLXPLAT_CPLD_LPC_REG_TACHO8_OFFSET ,
. mask = GENMASK ( 7 , 0 ) ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET ,
. bit = BIT ( 7 ) ,
2018-07-27 01:40:57 +03:00
} ,
{
. label = " tacho9 " ,
. reg = MLXPLAT_CPLD_LPC_REG_TACHO9_OFFSET ,
. mask = GENMASK ( 7 , 0 ) ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP2_OFFSET ,
. bit = BIT ( 0 ) ,
2018-07-27 01:40:57 +03:00
} ,
{
. label = " tacho10 " ,
. reg = MLXPLAT_CPLD_LPC_REG_TACHO10_OFFSET ,
. mask = GENMASK ( 7 , 0 ) ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP2_OFFSET ,
. bit = BIT ( 1 ) ,
2018-07-27 01:40:57 +03:00
} ,
{
. label = " tacho11 " ,
. reg = MLXPLAT_CPLD_LPC_REG_TACHO11_OFFSET ,
. mask = GENMASK ( 7 , 0 ) ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP2_OFFSET ,
. bit = BIT ( 2 ) ,
2018-07-27 01:40:57 +03:00
} ,
{
. label = " tacho12 " ,
. reg = MLXPLAT_CPLD_LPC_REG_TACHO12_OFFSET ,
. mask = GENMASK ( 7 , 0 ) ,
2018-12-13 02:59:15 +03:00
. capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP2_OFFSET ,
. bit = BIT ( 3 ) ,
2018-07-27 01:40:57 +03:00
} ,
2019-03-18 13:58:22 +03:00
{
. label = " conf " ,
. capability = MLXPLAT_CPLD_LPC_REG_TACHO_SPEED_OFFSET ,
} ,
2018-07-27 01:40:57 +03:00
} ;
static struct mlxreg_core_platform_data mlxplat_default_fan_data = {
. data = mlxplat_mlxcpld_default_fan_data ,
. counter = ARRAY_SIZE ( mlxplat_mlxcpld_default_fan_data ) ,
} ;
2019-03-18 13:58:23 +03:00
/* Watchdog type1: hardware implementation version1
* ( MSN2700 , MSN2410 , MSN2740 , MSN2100 and MSN2140 systems ) .
*/
static struct mlxreg_core_data mlxplat_mlxcpld_wd_main_regs_type1 [ ] = {
{
. label = " action " ,
. reg = MLXPLAT_CPLD_LPC_REG_WD1_ACT_OFFSET ,
. mask = MLXPLAT_CPLD_WD_RESET_ACT_MASK ,
. bit = 0 ,
} ,
{
. label = " timeout " ,
. reg = MLXPLAT_CPLD_LPC_REG_WD1_TMR_OFFSET ,
. mask = MLXPLAT_CPLD_WD_TYPE1_TO_MASK ,
. health_cntr = MLXPLAT_CPLD_WD_DFLT_TIMEOUT ,
} ,
{
. label = " ping " ,
. reg = MLXPLAT_CPLD_LPC_REG_WD_CLEAR_OFFSET ,
. mask = MLXPLAT_CPLD_WD1_CLEAR_MASK ,
. bit = 0 ,
} ,
{
. label = " reset " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 6 ) ,
. bit = 6 ,
} ,
} ;
static struct mlxreg_core_data mlxplat_mlxcpld_wd_aux_regs_type1 [ ] = {
{
. label = " action " ,
. reg = MLXPLAT_CPLD_LPC_REG_WD2_ACT_OFFSET ,
. mask = MLXPLAT_CPLD_WD_FAN_ACT_MASK ,
. bit = 4 ,
} ,
{
. label = " timeout " ,
. reg = MLXPLAT_CPLD_LPC_REG_WD2_TMR_OFFSET ,
. mask = MLXPLAT_CPLD_WD_TYPE1_TO_MASK ,
. health_cntr = MLXPLAT_CPLD_WD_DFLT_TIMEOUT ,
} ,
{
. label = " ping " ,
. reg = MLXPLAT_CPLD_LPC_REG_WD_CLEAR_OFFSET ,
. mask = MLXPLAT_CPLD_WD1_CLEAR_MASK ,
. bit = 1 ,
} ,
} ;
static struct mlxreg_core_platform_data mlxplat_mlxcpld_wd_set_type1 [ ] = {
{
. data = mlxplat_mlxcpld_wd_main_regs_type1 ,
. counter = ARRAY_SIZE ( mlxplat_mlxcpld_wd_main_regs_type1 ) ,
. version = MLX_WDT_TYPE1 ,
. identity = " mlx-wdt-main " ,
} ,
{
. data = mlxplat_mlxcpld_wd_aux_regs_type1 ,
. counter = ARRAY_SIZE ( mlxplat_mlxcpld_wd_aux_regs_type1 ) ,
. version = MLX_WDT_TYPE1 ,
. identity = " mlx-wdt-aux " ,
} ,
} ;
/* Watchdog type2: hardware implementation version 2
* ( all systems except ( MSN2700 , MSN2410 , MSN2740 , MSN2100 and MSN2140 ) .
*/
static struct mlxreg_core_data mlxplat_mlxcpld_wd_main_regs_type2 [ ] = {
{
. label = " action " ,
. reg = MLXPLAT_CPLD_LPC_REG_WD2_ACT_OFFSET ,
. mask = MLXPLAT_CPLD_WD_RESET_ACT_MASK ,
. bit = 0 ,
} ,
{
. label = " timeout " ,
. reg = MLXPLAT_CPLD_LPC_REG_WD2_TMR_OFFSET ,
. mask = MLXPLAT_CPLD_WD_TYPE2_TO_MASK ,
. health_cntr = MLXPLAT_CPLD_WD_DFLT_TIMEOUT ,
} ,
{
. label = " timeleft " ,
. reg = MLXPLAT_CPLD_LPC_REG_WD2_TLEFT_OFFSET ,
. mask = MLXPLAT_CPLD_WD_TYPE2_TO_MASK ,
} ,
{
. label = " ping " ,
. reg = MLXPLAT_CPLD_LPC_REG_WD2_ACT_OFFSET ,
. mask = MLXPLAT_CPLD_WD_RESET_ACT_MASK ,
. bit = 0 ,
} ,
{
. label = " reset " ,
. reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET ,
. mask = GENMASK ( 7 , 0 ) & ~ BIT ( 6 ) ,
. bit = 6 ,
} ,
} ;
static struct mlxreg_core_data mlxplat_mlxcpld_wd_aux_regs_type2 [ ] = {
{
. label = " action " ,
. reg = MLXPLAT_CPLD_LPC_REG_WD3_ACT_OFFSET ,
. mask = MLXPLAT_CPLD_WD_FAN_ACT_MASK ,
. bit = 4 ,
} ,
{
. label = " timeout " ,
. reg = MLXPLAT_CPLD_LPC_REG_WD3_TMR_OFFSET ,
. mask = MLXPLAT_CPLD_WD_TYPE2_TO_MASK ,
. health_cntr = MLXPLAT_CPLD_WD_DFLT_TIMEOUT ,
} ,
{
. label = " timeleft " ,
. reg = MLXPLAT_CPLD_LPC_REG_WD3_TLEFT_OFFSET ,
. mask = MLXPLAT_CPLD_WD_TYPE2_TO_MASK ,
} ,
{
. label = " ping " ,
. reg = MLXPLAT_CPLD_LPC_REG_WD3_ACT_OFFSET ,
. mask = MLXPLAT_CPLD_WD_FAN_ACT_MASK ,
. bit = 4 ,
} ,
} ;
static struct mlxreg_core_platform_data mlxplat_mlxcpld_wd_set_type2 [ ] = {
{
. data = mlxplat_mlxcpld_wd_main_regs_type2 ,
. counter = ARRAY_SIZE ( mlxplat_mlxcpld_wd_main_regs_type2 ) ,
. version = MLX_WDT_TYPE2 ,
. identity = " mlx-wdt-main " ,
} ,
{
. data = mlxplat_mlxcpld_wd_aux_regs_type2 ,
. counter = ARRAY_SIZE ( mlxplat_mlxcpld_wd_aux_regs_type2 ) ,
. version = MLX_WDT_TYPE2 ,
. identity = " mlx-wdt-aux " ,
} ,
} ;
2018-01-26 22:03:44 +03:00
static bool mlxplat_mlxcpld_writeable_reg ( struct device * dev , unsigned int reg )
{
switch ( reg ) {
2018-05-07 09:48:53 +03:00
case MLXPLAT_CPLD_LPC_REG_LED1_OFFSET :
case MLXPLAT_CPLD_LPC_REG_LED2_OFFSET :
case MLXPLAT_CPLD_LPC_REG_LED3_OFFSET :
case MLXPLAT_CPLD_LPC_REG_LED4_OFFSET :
case MLXPLAT_CPLD_LPC_REG_LED5_OFFSET :
2020-01-13 19:28:33 +03:00
case MLXPLAT_CPLD_LPC_REG_GP0_OFFSET :
2018-06-17 19:56:54 +03:00
case MLXPLAT_CPLD_LPC_REG_GP1_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WP1_OFFSET :
case MLXPLAT_CPLD_LPC_REG_GP2_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WP2_OFFSET :
2018-01-26 22:03:44 +03:00
case MLXPLAT_CPLD_LPC_REG_AGGR_MASK_OFFSET :
case MLXPLAT_CPLD_LPC_REG_AGGRLO_MASK_OFFSET :
2019-06-23 15:16:25 +03:00
case MLXPLAT_CPLD_LPC_REG_AGGRCO_MASK_OFFSET :
2020-01-13 19:28:36 +03:00
case MLXPLAT_CPLD_LPC_REG_AGGRCX_MASK_OFFSET :
2018-07-27 01:41:00 +03:00
case MLXPLAT_CPLD_LPC_REG_ASIC_EVENT_OFFSET :
case MLXPLAT_CPLD_LPC_REG_ASIC_MASK_OFFSET :
2018-01-26 22:03:44 +03:00
case MLXPLAT_CPLD_LPC_REG_PSU_EVENT_OFFSET :
case MLXPLAT_CPLD_LPC_REG_PSU_MASK_OFFSET :
case MLXPLAT_CPLD_LPC_REG_PWR_EVENT_OFFSET :
case MLXPLAT_CPLD_LPC_REG_PWR_MASK_OFFSET :
case MLXPLAT_CPLD_LPC_REG_FAN_EVENT_OFFSET :
case MLXPLAT_CPLD_LPC_REG_FAN_MASK_OFFSET :
2019-03-18 13:58:23 +03:00
case MLXPLAT_CPLD_LPC_REG_WD_CLEAR_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WD_CLEAR_WP_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WD1_TMR_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WD1_ACT_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WD2_TMR_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WD2_ACT_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WD3_TMR_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WD3_ACT_OFFSET :
2018-07-27 01:40:57 +03:00
case MLXPLAT_CPLD_LPC_REG_PWM1_OFFSET :
case MLXPLAT_CPLD_LPC_REG_PWM_CONTROL_OFFSET :
2018-01-26 22:03:44 +03:00
return true ;
}
return false ;
}
static bool mlxplat_mlxcpld_readable_reg ( struct device * dev , unsigned int reg )
{
switch ( reg ) {
2018-06-17 19:56:54 +03:00
case MLXPLAT_CPLD_LPC_REG_CPLD1_VER_OFFSET :
case MLXPLAT_CPLD_LPC_REG_CPLD2_VER_OFFSET :
2018-11-15 20:26:54 +03:00
case MLXPLAT_CPLD_LPC_REG_CPLD3_VER_OFFSET :
2019-02-26 11:20:32 +03:00
case MLXPLAT_CPLD_LPC_REG_CPLD4_VER_OFFSET :
2018-06-17 19:56:54 +03:00
case MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET :
2018-11-15 20:26:54 +03:00
case MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET :
case MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET :
2018-05-07 09:48:53 +03:00
case MLXPLAT_CPLD_LPC_REG_LED1_OFFSET :
case MLXPLAT_CPLD_LPC_REG_LED2_OFFSET :
case MLXPLAT_CPLD_LPC_REG_LED3_OFFSET :
case MLXPLAT_CPLD_LPC_REG_LED4_OFFSET :
case MLXPLAT_CPLD_LPC_REG_LED5_OFFSET :
2018-12-13 02:59:11 +03:00
case MLXPLAT_CPLD_LPC_REG_FAN_DIRECTION :
2020-01-13 19:28:33 +03:00
case MLXPLAT_CPLD_LPC_REG_GP0_RO_OFFSET :
case MLXPLAT_CPLD_LPC_REG_GP0_OFFSET :
2018-06-17 19:56:54 +03:00
case MLXPLAT_CPLD_LPC_REG_GP1_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WP1_OFFSET :
case MLXPLAT_CPLD_LPC_REG_GP2_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WP2_OFFSET :
2018-01-26 22:03:44 +03:00
case MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET :
case MLXPLAT_CPLD_LPC_REG_AGGR_MASK_OFFSET :
case MLXPLAT_CPLD_LPC_REG_AGGRLO_OFFSET :
case MLXPLAT_CPLD_LPC_REG_AGGRLO_MASK_OFFSET :
2019-06-23 15:16:25 +03:00
case MLXPLAT_CPLD_LPC_REG_AGGRCO_OFFSET :
case MLXPLAT_CPLD_LPC_REG_AGGRCO_MASK_OFFSET :
2020-01-13 19:28:36 +03:00
case MLXPLAT_CPLD_LPC_REG_AGGRCX_OFFSET :
case MLXPLAT_CPLD_LPC_REG_AGGRCX_MASK_OFFSET :
2018-06-17 19:56:54 +03:00
case MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET :
2018-07-27 01:41:00 +03:00
case MLXPLAT_CPLD_LPC_REG_ASIC_EVENT_OFFSET :
case MLXPLAT_CPLD_LPC_REG_ASIC_MASK_OFFSET :
2018-01-26 22:03:44 +03:00
case MLXPLAT_CPLD_LPC_REG_PSU_OFFSET :
case MLXPLAT_CPLD_LPC_REG_PSU_EVENT_OFFSET :
case MLXPLAT_CPLD_LPC_REG_PSU_MASK_OFFSET :
case MLXPLAT_CPLD_LPC_REG_PWR_OFFSET :
case MLXPLAT_CPLD_LPC_REG_PWR_EVENT_OFFSET :
case MLXPLAT_CPLD_LPC_REG_PWR_MASK_OFFSET :
case MLXPLAT_CPLD_LPC_REG_FAN_OFFSET :
case MLXPLAT_CPLD_LPC_REG_FAN_EVENT_OFFSET :
case MLXPLAT_CPLD_LPC_REG_FAN_MASK_OFFSET :
2019-03-18 13:58:23 +03:00
case MLXPLAT_CPLD_LPC_REG_WD_CLEAR_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WD_CLEAR_WP_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WD1_TMR_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WD1_ACT_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WD2_TMR_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WD2_TLEFT_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WD2_ACT_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WD3_TMR_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WD3_TLEFT_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WD3_ACT_OFFSET :
2018-07-27 01:40:57 +03:00
case MLXPLAT_CPLD_LPC_REG_PWM1_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO1_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO2_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO3_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO4_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO5_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO6_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO7_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO8_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO9_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO10_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO11_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO12_OFFSET :
case MLXPLAT_CPLD_LPC_REG_PWM_CONTROL_OFFSET :
2018-12-13 02:59:15 +03:00
case MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET :
case MLXPLAT_CPLD_LPC_REG_FAN_CAP2_OFFSET :
case MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET :
2019-03-18 13:58:22 +03:00
case MLXPLAT_CPLD_LPC_REG_TACHO_SPEED_OFFSET :
2020-01-13 19:28:37 +03:00
case MLXPLAT_CPLD_LPC_REG_PSU_I2C_CAP_OFFSET :
2020-01-13 19:28:33 +03:00
case MLXPLAT_CPLD_LPC_REG_CONFIG1_OFFSET :
case MLXPLAT_CPLD_LPC_REG_CONFIG2_OFFSET :
case MLXPLAT_CPLD_LPC_REG_UFM_VERSION_OFFSET :
2018-01-26 22:03:44 +03:00
return true ;
}
return false ;
}
static bool mlxplat_mlxcpld_volatile_reg ( struct device * dev , unsigned int reg )
{
switch ( reg ) {
2018-06-17 19:56:54 +03:00
case MLXPLAT_CPLD_LPC_REG_CPLD1_VER_OFFSET :
case MLXPLAT_CPLD_LPC_REG_CPLD2_VER_OFFSET :
2018-11-15 20:26:54 +03:00
case MLXPLAT_CPLD_LPC_REG_CPLD3_VER_OFFSET :
2019-02-26 11:20:32 +03:00
case MLXPLAT_CPLD_LPC_REG_CPLD4_VER_OFFSET :
2018-06-17 19:56:54 +03:00
case MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET :
2018-11-15 20:26:54 +03:00
case MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET :
case MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET :
2018-05-07 09:48:53 +03:00
case MLXPLAT_CPLD_LPC_REG_LED1_OFFSET :
case MLXPLAT_CPLD_LPC_REG_LED2_OFFSET :
case MLXPLAT_CPLD_LPC_REG_LED3_OFFSET :
case MLXPLAT_CPLD_LPC_REG_LED4_OFFSET :
case MLXPLAT_CPLD_LPC_REG_LED5_OFFSET :
2018-12-13 02:59:11 +03:00
case MLXPLAT_CPLD_LPC_REG_FAN_DIRECTION :
2020-01-13 19:28:33 +03:00
case MLXPLAT_CPLD_LPC_REG_GP0_RO_OFFSET :
case MLXPLAT_CPLD_LPC_REG_GP0_OFFSET :
2018-06-17 19:56:54 +03:00
case MLXPLAT_CPLD_LPC_REG_GP1_OFFSET :
case MLXPLAT_CPLD_LPC_REG_GP2_OFFSET :
2018-01-26 22:03:44 +03:00
case MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET :
case MLXPLAT_CPLD_LPC_REG_AGGR_MASK_OFFSET :
case MLXPLAT_CPLD_LPC_REG_AGGRLO_OFFSET :
case MLXPLAT_CPLD_LPC_REG_AGGRLO_MASK_OFFSET :
2019-06-23 15:16:25 +03:00
case MLXPLAT_CPLD_LPC_REG_AGGRCO_OFFSET :
case MLXPLAT_CPLD_LPC_REG_AGGRCO_MASK_OFFSET :
2020-01-13 19:28:36 +03:00
case MLXPLAT_CPLD_LPC_REG_AGGRCX_OFFSET :
case MLXPLAT_CPLD_LPC_REG_AGGRCX_MASK_OFFSET :
2018-06-17 19:56:54 +03:00
case MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET :
2018-07-27 01:41:00 +03:00
case MLXPLAT_CPLD_LPC_REG_ASIC_EVENT_OFFSET :
case MLXPLAT_CPLD_LPC_REG_ASIC_MASK_OFFSET :
2018-01-26 22:03:44 +03:00
case MLXPLAT_CPLD_LPC_REG_PSU_OFFSET :
case MLXPLAT_CPLD_LPC_REG_PSU_EVENT_OFFSET :
case MLXPLAT_CPLD_LPC_REG_PSU_MASK_OFFSET :
case MLXPLAT_CPLD_LPC_REG_PWR_OFFSET :
case MLXPLAT_CPLD_LPC_REG_PWR_EVENT_OFFSET :
case MLXPLAT_CPLD_LPC_REG_PWR_MASK_OFFSET :
case MLXPLAT_CPLD_LPC_REG_FAN_OFFSET :
case MLXPLAT_CPLD_LPC_REG_FAN_EVENT_OFFSET :
case MLXPLAT_CPLD_LPC_REG_FAN_MASK_OFFSET :
2019-03-18 13:58:23 +03:00
case MLXPLAT_CPLD_LPC_REG_WD2_TMR_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WD2_TLEFT_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WD3_TMR_OFFSET :
case MLXPLAT_CPLD_LPC_REG_WD3_TLEFT_OFFSET :
2018-07-27 01:40:57 +03:00
case MLXPLAT_CPLD_LPC_REG_PWM1_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO1_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO2_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO3_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO4_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO5_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO6_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO7_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO8_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO9_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO10_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO11_OFFSET :
case MLXPLAT_CPLD_LPC_REG_TACHO12_OFFSET :
case MLXPLAT_CPLD_LPC_REG_PWM_CONTROL_OFFSET :
2018-12-13 02:59:15 +03:00
case MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET :
case MLXPLAT_CPLD_LPC_REG_FAN_CAP2_OFFSET :
case MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET :
2019-03-18 13:58:22 +03:00
case MLXPLAT_CPLD_LPC_REG_TACHO_SPEED_OFFSET :
2020-01-13 19:28:37 +03:00
case MLXPLAT_CPLD_LPC_REG_PSU_I2C_CAP_OFFSET :
2020-01-13 19:28:33 +03:00
case MLXPLAT_CPLD_LPC_REG_CONFIG1_OFFSET :
case MLXPLAT_CPLD_LPC_REG_CONFIG2_OFFSET :
case MLXPLAT_CPLD_LPC_REG_UFM_VERSION_OFFSET :
2018-01-26 22:03:44 +03:00
return true ;
}
return false ;
}
2018-06-17 19:56:54 +03:00
static const struct reg_default mlxplat_mlxcpld_regmap_default [ ] = {
{ MLXPLAT_CPLD_LPC_REG_WP1_OFFSET , 0x00 } ,
{ MLXPLAT_CPLD_LPC_REG_WP2_OFFSET , 0x00 } ,
2018-07-27 01:40:57 +03:00
{ MLXPLAT_CPLD_LPC_REG_PWM_CONTROL_OFFSET , 0x00 } ,
2019-03-18 13:58:23 +03:00
{ MLXPLAT_CPLD_LPC_REG_WD_CLEAR_WP_OFFSET , 0x00 } ,
2018-06-17 19:56:54 +03:00
} ;
2019-06-23 15:16:26 +03:00
static const struct reg_default mlxplat_mlxcpld_regmap_ng [ ] = {
{ MLXPLAT_CPLD_LPC_REG_PWM_CONTROL_OFFSET , 0x00 } ,
{ MLXPLAT_CPLD_LPC_REG_WD_CLEAR_WP_OFFSET , 0x00 } ,
} ;
2020-01-13 19:28:36 +03:00
static const struct reg_default mlxplat_mlxcpld_regmap_comex_default [ ] = {
{ MLXPLAT_CPLD_LPC_REG_AGGRCX_MASK_OFFSET ,
MLXPLAT_CPLD_LOW_AGGRCX_MASK } ,
{ MLXPLAT_CPLD_LPC_REG_PWM_CONTROL_OFFSET , 0x00 } ,
} ;
2018-01-23 06:55:11 +03:00
struct mlxplat_mlxcpld_regmap_context {
void __iomem * base ;
} ;
static struct mlxplat_mlxcpld_regmap_context mlxplat_mlxcpld_regmap_ctx ;
static int
mlxplat_mlxcpld_reg_read ( void * context , unsigned int reg , unsigned int * val )
{
struct mlxplat_mlxcpld_regmap_context * ctx = context ;
* val = ioread8 ( ctx - > base + reg ) ;
return 0 ;
}
static int
mlxplat_mlxcpld_reg_write ( void * context , unsigned int reg , unsigned int val )
{
struct mlxplat_mlxcpld_regmap_context * ctx = context ;
iowrite8 ( val , ctx - > base + reg ) ;
return 0 ;
}
static const struct regmap_config mlxplat_mlxcpld_regmap_config = {
. reg_bits = 8 ,
. val_bits = 8 ,
. max_register = 255 ,
2018-01-26 22:03:44 +03:00
. cache_type = REGCACHE_FLAT ,
. writeable_reg = mlxplat_mlxcpld_writeable_reg ,
. readable_reg = mlxplat_mlxcpld_readable_reg ,
. volatile_reg = mlxplat_mlxcpld_volatile_reg ,
2018-06-17 19:56:54 +03:00
. reg_defaults = mlxplat_mlxcpld_regmap_default ,
. num_reg_defaults = ARRAY_SIZE ( mlxplat_mlxcpld_regmap_default ) ,
2018-01-23 06:55:11 +03:00
. reg_read = mlxplat_mlxcpld_reg_read ,
. reg_write = mlxplat_mlxcpld_reg_write ,
2016-10-27 22:55:54 +03:00
} ;
2019-06-23 15:16:26 +03:00
static const struct regmap_config mlxplat_mlxcpld_regmap_config_ng = {
. reg_bits = 8 ,
. val_bits = 8 ,
. max_register = 255 ,
. cache_type = REGCACHE_FLAT ,
. writeable_reg = mlxplat_mlxcpld_writeable_reg ,
. readable_reg = mlxplat_mlxcpld_readable_reg ,
. volatile_reg = mlxplat_mlxcpld_volatile_reg ,
. reg_defaults = mlxplat_mlxcpld_regmap_ng ,
. num_reg_defaults = ARRAY_SIZE ( mlxplat_mlxcpld_regmap_ng ) ,
. reg_read = mlxplat_mlxcpld_reg_read ,
. reg_write = mlxplat_mlxcpld_reg_write ,
} ;
2020-01-13 19:28:36 +03:00
static const struct regmap_config mlxplat_mlxcpld_regmap_config_comex = {
. reg_bits = 8 ,
. val_bits = 8 ,
. max_register = 255 ,
. cache_type = REGCACHE_FLAT ,
. writeable_reg = mlxplat_mlxcpld_writeable_reg ,
. readable_reg = mlxplat_mlxcpld_readable_reg ,
. volatile_reg = mlxplat_mlxcpld_volatile_reg ,
. reg_defaults = mlxplat_mlxcpld_regmap_comex_default ,
. num_reg_defaults = ARRAY_SIZE ( mlxplat_mlxcpld_regmap_comex_default ) ,
. reg_read = mlxplat_mlxcpld_reg_read ,
. reg_write = mlxplat_mlxcpld_reg_write ,
} ;
2016-12-14 15:05:15 +03:00
static struct resource mlxplat_mlxcpld_resources [ ] = {
2018-01-17 21:21:53 +03:00
[ 0 ] = DEFINE_RES_IRQ_NAMED ( 17 , " mlxreg-hotplug " ) ,
2016-10-27 22:55:54 +03:00
} ;
2017-10-05 13:42:11 +03:00
static struct platform_device * mlxplat_dev ;
2019-06-23 15:16:25 +03:00
static struct mlxreg_core_hotplug_platform_data * mlxplat_i2c ;
2018-01-23 06:55:11 +03:00
static struct mlxreg_core_hotplug_platform_data * mlxplat_hotplug ;
2018-05-07 09:48:53 +03:00
static struct mlxreg_core_platform_data * mlxplat_led ;
2018-06-17 19:56:54 +03:00
static struct mlxreg_core_platform_data * mlxplat_regs_io ;
2018-07-27 01:40:57 +03:00
static struct mlxreg_core_platform_data * mlxplat_fan ;
2019-03-18 13:58:23 +03:00
static struct mlxreg_core_platform_data
* mlxplat_wd_data [ MLXPLAT_CPLD_WD_MAX_DEVS ] ;
2019-06-23 15:16:24 +03:00
static const struct regmap_config * mlxplat_regmap_config ;
2016-09-23 00:13:42 +03:00
static int __init mlxplat_dmi_default_matched ( const struct dmi_system_id * dmi )
{
int i ;
2020-01-13 19:28:35 +03:00
mlxplat_max_adap_num = MLXPLAT_CPLD_MAX_PHYS_ADAPTER_NUM ;
mlxplat_mux_num = ARRAY_SIZE ( mlxplat_default_mux_data ) ;
mlxplat_mux_data = mlxplat_default_mux_data ;
for ( i = 0 ; i < mlxplat_mux_num ; i + + ) {
2016-09-23 00:13:42 +03:00
mlxplat_mux_data [ i ] . values = mlxplat_default_channels [ i ] ;
mlxplat_mux_data [ i ] . n_values =
ARRAY_SIZE ( mlxplat_default_channels [ i ] ) ;
}
2016-12-14 15:05:15 +03:00
mlxplat_hotplug = & mlxplat_mlxcpld_default_data ;
2018-02-14 01:09:34 +03:00
mlxplat_hotplug - > deferred_nr =
mlxplat_default_channels [ i - 1 ] [ MLXPLAT_CPLD_GRP_CHNL_NUM - 1 ] ;
2018-05-07 09:48:53 +03:00
mlxplat_led = & mlxplat_default_led_data ;
2018-06-17 19:56:54 +03:00
mlxplat_regs_io = & mlxplat_default_regs_io_data ;
2019-03-18 13:58:23 +03:00
mlxplat_wd_data [ 0 ] = & mlxplat_mlxcpld_wd_set_type1 [ 0 ] ;
2016-09-23 00:13:42 +03:00
return 1 ;
2020-01-13 19:28:29 +03:00
}
2016-09-23 00:13:42 +03:00
static int __init mlxplat_dmi_msn21xx_matched ( const struct dmi_system_id * dmi )
{
int i ;
2020-01-13 19:28:35 +03:00
mlxplat_max_adap_num = MLXPLAT_CPLD_MAX_PHYS_ADAPTER_NUM ;
mlxplat_mux_num = ARRAY_SIZE ( mlxplat_default_mux_data ) ;
mlxplat_mux_data = mlxplat_default_mux_data ;
for ( i = 0 ; i < mlxplat_mux_num ; i + + ) {
2016-09-23 00:13:42 +03:00
mlxplat_mux_data [ i ] . values = mlxplat_msn21xx_channels ;
mlxplat_mux_data [ i ] . n_values =
ARRAY_SIZE ( mlxplat_msn21xx_channels ) ;
}
2016-12-14 15:05:15 +03:00
mlxplat_hotplug = & mlxplat_mlxcpld_msn21xx_data ;
2018-02-14 01:09:34 +03:00
mlxplat_hotplug - > deferred_nr =
mlxplat_msn21xx_channels [ MLXPLAT_CPLD_GRP_CHNL_NUM - 1 ] ;
2018-05-07 09:48:53 +03:00
mlxplat_led = & mlxplat_msn21xx_led_data ;
2018-07-27 01:41:01 +03:00
mlxplat_regs_io = & mlxplat_msn21xx_regs_io_data ;
2019-03-18 13:58:23 +03:00
mlxplat_wd_data [ 0 ] = & mlxplat_mlxcpld_wd_set_type1 [ 0 ] ;
2016-09-23 00:13:42 +03:00
return 1 ;
2020-01-13 19:28:29 +03:00
}
2016-09-23 00:13:42 +03:00
2018-02-10 02:59:30 +03:00
static int __init mlxplat_dmi_msn274x_matched ( const struct dmi_system_id * dmi )
{
int i ;
2020-01-13 19:28:35 +03:00
mlxplat_max_adap_num = MLXPLAT_CPLD_MAX_PHYS_ADAPTER_NUM ;
mlxplat_mux_num = ARRAY_SIZE ( mlxplat_default_mux_data ) ;
mlxplat_mux_data = mlxplat_default_mux_data ;
for ( i = 0 ; i < mlxplat_mux_num ; i + + ) {
2018-02-10 02:59:30 +03:00
mlxplat_mux_data [ i ] . values = mlxplat_msn21xx_channels ;
mlxplat_mux_data [ i ] . n_values =
ARRAY_SIZE ( mlxplat_msn21xx_channels ) ;
}
mlxplat_hotplug = & mlxplat_mlxcpld_msn274x_data ;
2018-02-14 01:09:34 +03:00
mlxplat_hotplug - > deferred_nr =
mlxplat_msn21xx_channels [ MLXPLAT_CPLD_GRP_CHNL_NUM - 1 ] ;
2018-05-07 09:48:53 +03:00
mlxplat_led = & mlxplat_default_led_data ;
2018-07-27 01:41:03 +03:00
mlxplat_regs_io = & mlxplat_msn21xx_regs_io_data ;
2019-03-18 13:58:23 +03:00
mlxplat_wd_data [ 0 ] = & mlxplat_mlxcpld_wd_set_type1 [ 0 ] ;
2018-02-10 02:59:30 +03:00
return 1 ;
2020-01-13 19:28:29 +03:00
}
2018-02-10 02:59:30 +03:00
2018-02-10 02:59:31 +03:00
static int __init mlxplat_dmi_msn201x_matched ( const struct dmi_system_id * dmi )
{
int i ;
2020-01-13 19:28:35 +03:00
mlxplat_max_adap_num = MLXPLAT_CPLD_MAX_PHYS_ADAPTER_NUM ;
mlxplat_mux_num = ARRAY_SIZE ( mlxplat_default_mux_data ) ;
mlxplat_mux_data = mlxplat_default_mux_data ;
for ( i = 0 ; i < mlxplat_mux_num ; i + + ) {
2018-02-10 02:59:31 +03:00
mlxplat_mux_data [ i ] . values = mlxplat_msn21xx_channels ;
mlxplat_mux_data [ i ] . n_values =
ARRAY_SIZE ( mlxplat_msn21xx_channels ) ;
}
mlxplat_hotplug = & mlxplat_mlxcpld_msn201x_data ;
2018-02-14 01:09:34 +03:00
mlxplat_hotplug - > deferred_nr =
mlxplat_default_channels [ i - 1 ] [ MLXPLAT_CPLD_GRP_CHNL_NUM - 1 ] ;
2018-11-15 20:26:57 +03:00
mlxplat_led = & mlxplat_msn21xx_led_data ;
2018-07-27 01:41:01 +03:00
mlxplat_regs_io = & mlxplat_msn21xx_regs_io_data ;
2019-03-18 13:58:23 +03:00
mlxplat_wd_data [ 0 ] = & mlxplat_mlxcpld_wd_set_type1 [ 0 ] ;
2018-02-10 02:59:31 +03:00
return 1 ;
2020-01-13 19:28:29 +03:00
}
2018-02-10 02:59:31 +03:00
2018-02-10 02:59:32 +03:00
static int __init mlxplat_dmi_qmb7xx_matched ( const struct dmi_system_id * dmi )
{
int i ;
2020-01-13 19:28:35 +03:00
mlxplat_max_adap_num = MLXPLAT_CPLD_MAX_PHYS_ADAPTER_NUM ;
mlxplat_mux_num = ARRAY_SIZE ( mlxplat_default_mux_data ) ;
mlxplat_mux_data = mlxplat_default_mux_data ;
for ( i = 0 ; i < mlxplat_mux_num ; i + + ) {
2018-02-10 02:59:32 +03:00
mlxplat_mux_data [ i ] . values = mlxplat_msn21xx_channels ;
mlxplat_mux_data [ i ] . n_values =
ARRAY_SIZE ( mlxplat_msn21xx_channels ) ;
}
mlxplat_hotplug = & mlxplat_mlxcpld_default_ng_data ;
2018-02-14 01:09:34 +03:00
mlxplat_hotplug - > deferred_nr =
mlxplat_msn21xx_channels [ MLXPLAT_CPLD_GRP_CHNL_NUM - 1 ] ;
2018-11-15 20:26:57 +03:00
mlxplat_led = & mlxplat_default_ng_led_data ;
2018-11-15 20:26:58 +03:00
mlxplat_regs_io = & mlxplat_default_ng_regs_io_data ;
2018-07-27 01:40:57 +03:00
mlxplat_fan = & mlxplat_default_fan_data ;
2019-03-18 13:58:23 +03:00
for ( i = 0 ; i < ARRAY_SIZE ( mlxplat_mlxcpld_wd_set_type2 ) ; i + + )
mlxplat_wd_data [ i ] = & mlxplat_mlxcpld_wd_set_type2 [ i ] ;
2019-06-23 15:16:25 +03:00
mlxplat_i2c = & mlxplat_mlxcpld_i2c_ng_data ;
2019-06-23 15:16:26 +03:00
mlxplat_regmap_config = & mlxplat_mlxcpld_regmap_config_ng ;
2018-02-10 02:59:32 +03:00
return 1 ;
2020-01-13 19:28:29 +03:00
}
2018-02-10 02:59:32 +03:00
2020-01-13 19:28:36 +03:00
static int __init mlxplat_dmi_comex_matched ( const struct dmi_system_id * dmi )
{
int i ;
mlxplat_max_adap_num = MLXPLAT_CPLD_MAX_PHYS_EXT_ADAPTER_NUM ;
mlxplat_mux_num = ARRAY_SIZE ( mlxplat_extended_mux_data ) ;
mlxplat_mux_data = mlxplat_extended_mux_data ;
for ( i = 0 ; i < mlxplat_mux_num ; i + + ) {
mlxplat_mux_data [ i ] . values = mlxplat_msn21xx_channels ;
mlxplat_mux_data [ i ] . n_values =
ARRAY_SIZE ( mlxplat_msn21xx_channels ) ;
}
mlxplat_hotplug = & mlxplat_mlxcpld_comex_data ;
mlxplat_hotplug - > deferred_nr = MLXPLAT_CPLD_MAX_PHYS_EXT_ADAPTER_NUM ;
mlxplat_led = & mlxplat_comex_100G_led_data ;
mlxplat_regs_io = & mlxplat_default_ng_regs_io_data ;
mlxplat_fan = & mlxplat_default_fan_data ;
for ( i = 0 ; i < ARRAY_SIZE ( mlxplat_mlxcpld_wd_set_type2 ) ; i + + )
mlxplat_wd_data [ i ] = & mlxplat_mlxcpld_wd_set_type2 [ i ] ;
mlxplat_regmap_config = & mlxplat_mlxcpld_regmap_config_comex ;
return 1 ;
}
2017-09-14 12:59:30 +03:00
static const struct dmi_system_id mlxplat_dmi_table [ ] __initconst = {
platform/x86: mlx-platform: Modify DMI matching order
Modify DMI matching order: perform matching based on DMI_BOARD_NAME
before matching based on DMI_BOARD_VENDOR and DMI_PRODUCT_NAME in order
to reduce the number of ‘dmi_table’ entries necessary for new systems
support and keep matching order in logical way.
For example, the existing check for DMI_PRODUCT_NAME with prefixes
“MSN27", “MSN24”, "MSB” matches systems MSN2700-BXXXX, MSN2700-XXXX,
MSN2410-BXXXX, MSB7800-XXXX, where ‘XXXX’ specifies some systems
hardware flavors.
At the same time these systems also matched by DMI_BOARD_NAME
“VMOD0001”, because they all have the same platform configuration (LED,
interrupt control, mux etcetera).
New systems with different platform configuration, but with similar
DMI_PRODUCT_NAME MSN2700-2XXXX, MSN2700-2XXXX, MSB7800-2XXXX are about
to be added. These system have similar DMI_PRODUCT_NAME, since they
have same ports configuration as their predecessors. All new systems
will be matched by DMI_BOARD_NAME “VMOD0008”.
With the change provided in the patch it is enough just to add
“VMOD0008” match following natural after “VMOD0007”, otherwise
“VMOD0008” or all “MSN2700-2XXXX”, “MSN2700-2XXXX”, “MSB7800-2XXXX”
should be added on top of ‘mlxplat_dmi_table” in order to be matched
before “MSN27", “MSN24”, "MSB”.
Signed-off-by: Vadim Pasternak <vadimp@mellanox.com>
Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
2019-06-23 15:16:27 +03:00
{
. callback = mlxplat_dmi_default_matched ,
. matches = {
DMI_MATCH ( DMI_BOARD_NAME , " VMOD0001 " ) ,
} ,
} ,
{
. callback = mlxplat_dmi_msn21xx_matched ,
. matches = {
DMI_MATCH ( DMI_BOARD_NAME , " VMOD0002 " ) ,
} ,
} ,
{
. callback = mlxplat_dmi_msn274x_matched ,
. matches = {
DMI_MATCH ( DMI_BOARD_NAME , " VMOD0003 " ) ,
} ,
} ,
{
. callback = mlxplat_dmi_msn201x_matched ,
. matches = {
DMI_MATCH ( DMI_BOARD_NAME , " VMOD0004 " ) ,
} ,
} ,
{
. callback = mlxplat_dmi_qmb7xx_matched ,
. matches = {
DMI_MATCH ( DMI_BOARD_NAME , " VMOD0005 " ) ,
} ,
} ,
{
. callback = mlxplat_dmi_qmb7xx_matched ,
. matches = {
DMI_MATCH ( DMI_BOARD_NAME , " VMOD0007 " ) ,
} ,
} ,
2020-01-13 19:28:36 +03:00
{
. callback = mlxplat_dmi_comex_matched ,
. matches = {
DMI_MATCH ( DMI_BOARD_NAME , " VMOD0009 " ) ,
} ,
} ,
2018-02-10 02:59:30 +03:00
{
. callback = mlxplat_dmi_msn274x_matched ,
. matches = {
DMI_MATCH ( DMI_BOARD_VENDOR , " Mellanox Technologies " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " MSN274 " ) ,
} ,
} ,
2016-09-23 00:13:42 +03:00
{
. callback = mlxplat_dmi_default_matched ,
. matches = {
DMI_MATCH ( DMI_BOARD_VENDOR , " Mellanox Technologies " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " MSN24 " ) ,
} ,
} ,
{
. callback = mlxplat_dmi_default_matched ,
. matches = {
DMI_MATCH ( DMI_BOARD_VENDOR , " Mellanox Technologies " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " MSN27 " ) ,
} ,
} ,
{
. callback = mlxplat_dmi_default_matched ,
. matches = {
DMI_MATCH ( DMI_BOARD_VENDOR , " Mellanox Technologies " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " MSB " ) ,
} ,
} ,
{
. callback = mlxplat_dmi_default_matched ,
. matches = {
DMI_MATCH ( DMI_BOARD_VENDOR , " Mellanox Technologies " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " MSX " ) ,
} ,
} ,
{
. callback = mlxplat_dmi_msn21xx_matched ,
. matches = {
DMI_MATCH ( DMI_BOARD_VENDOR , " Mellanox Technologies " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " MSN21 " ) ,
} ,
} ,
2018-02-10 02:59:31 +03:00
{
. callback = mlxplat_dmi_msn201x_matched ,
. matches = {
DMI_MATCH ( DMI_BOARD_VENDOR , " Mellanox Technologies " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " MSN201 " ) ,
} ,
} ,
2018-02-10 02:59:32 +03:00
{
. callback = mlxplat_dmi_qmb7xx_matched ,
. matches = {
DMI_MATCH ( DMI_BOARD_VENDOR , " Mellanox Technologies " ) ,
2018-11-15 20:26:55 +03:00
DMI_MATCH ( DMI_PRODUCT_NAME , " MQM87 " ) ,
2018-02-10 02:59:32 +03:00
} ,
} ,
{
. callback = mlxplat_dmi_qmb7xx_matched ,
. matches = {
DMI_MATCH ( DMI_BOARD_VENDOR , " Mellanox Technologies " ) ,
2018-11-15 20:26:55 +03:00
DMI_MATCH ( DMI_PRODUCT_NAME , " MSN37 " ) ,
2018-02-10 02:59:32 +03:00
} ,
} ,
{
. callback = mlxplat_dmi_qmb7xx_matched ,
. matches = {
DMI_MATCH ( DMI_BOARD_VENDOR , " Mellanox Technologies " ) ,
2018-11-15 20:26:55 +03:00
DMI_MATCH ( DMI_PRODUCT_NAME , " MSN34 " ) ,
2018-02-10 02:59:32 +03:00
} ,
} ,
2018-12-13 02:59:16 +03:00
{
. callback = mlxplat_dmi_qmb7xx_matched ,
. matches = {
DMI_MATCH ( DMI_BOARD_VENDOR , " Mellanox Technologies " ) ,
DMI_MATCH ( DMI_PRODUCT_NAME , " MSN38 " ) ,
} ,
} ,
2016-09-23 00:13:42 +03:00
{ }
} ;
2018-01-22 17:20:43 +03:00
MODULE_DEVICE_TABLE ( dmi , mlxplat_dmi_table ) ;
2018-02-14 01:09:36 +03:00
static int mlxplat_mlxcpld_verify_bus_topology ( int * nr )
{
struct i2c_adapter * search_adap ;
int shift , i ;
/* Scan adapters from expected id to verify it is free. */
* nr = MLXPLAT_CPLD_PHYS_ADAPTER_DEF_NR ;
for ( i = MLXPLAT_CPLD_PHYS_ADAPTER_DEF_NR ; i <
2020-01-13 19:28:35 +03:00
mlxplat_max_adap_num ; i + + ) {
2018-02-14 01:09:36 +03:00
search_adap = i2c_get_adapter ( i ) ;
if ( search_adap ) {
i2c_put_adapter ( search_adap ) ;
continue ;
}
/* Return if expected parent adapter is free. */
if ( i = = MLXPLAT_CPLD_PHYS_ADAPTER_DEF_NR )
return 0 ;
break ;
}
/* Return with error if free id for adapter is not found. */
2020-01-13 19:28:35 +03:00
if ( i = = mlxplat_max_adap_num )
2018-02-14 01:09:36 +03:00
return - ENODEV ;
/* Shift adapter ids, since expected parent adapter is not free. */
* nr = i ;
2020-01-13 19:28:35 +03:00
for ( i = 0 ; i < mlxplat_mux_num ; i + + ) {
2018-02-14 01:09:36 +03:00
shift = * nr - mlxplat_mux_data [ i ] . parent ;
mlxplat_mux_data [ i ] . parent = * nr ;
mlxplat_mux_data [ i ] . base_nr + = shift ;
if ( shift > 0 )
mlxplat_hotplug - > shift_nr = shift ;
}
return 0 ;
}
2016-09-23 00:13:42 +03:00
static int __init mlxplat_init ( void )
{
struct mlxplat_priv * priv ;
2018-06-17 19:56:54 +03:00
int i , j , nr , err ;
2016-09-23 00:13:42 +03:00
if ( ! dmi_check_system ( mlxplat_dmi_table ) )
return - ENODEV ;
mlxplat_dev = platform_device_register_simple ( MLX_PLAT_DEVICE_NAME , - 1 ,
mlxplat_lpc_resources ,
ARRAY_SIZE ( mlxplat_lpc_resources ) ) ;
2016-09-24 14:48:13 +03:00
if ( IS_ERR ( mlxplat_dev ) )
return PTR_ERR ( mlxplat_dev ) ;
2016-09-23 00:13:42 +03:00
priv = devm_kzalloc ( & mlxplat_dev - > dev , sizeof ( struct mlxplat_priv ) ,
GFP_KERNEL ) ;
if ( ! priv ) {
err = - ENOMEM ;
goto fail_alloc ;
}
platform_set_drvdata ( mlxplat_dev , priv ) ;
2019-06-23 15:16:24 +03:00
mlxplat_mlxcpld_regmap_ctx . base = devm_ioport_map ( & mlxplat_dev - > dev ,
mlxplat_lpc_resources [ 1 ] . start , 1 ) ;
if ( ! mlxplat_mlxcpld_regmap_ctx . base ) {
err = - ENOMEM ;
goto fail_alloc ;
}
if ( ! mlxplat_regmap_config )
mlxplat_regmap_config = & mlxplat_mlxcpld_regmap_config ;
priv - > regmap = devm_regmap_init ( & mlxplat_dev - > dev , NULL ,
& mlxplat_mlxcpld_regmap_ctx ,
mlxplat_regmap_config ) ;
if ( IS_ERR ( priv - > regmap ) ) {
err = PTR_ERR ( priv - > regmap ) ;
2019-07-09 04:38:42 +03:00
goto fail_alloc ;
2019-06-23 15:16:24 +03:00
}
2018-02-14 01:09:36 +03:00
err = mlxplat_mlxcpld_verify_bus_topology ( & nr ) ;
if ( nr < 0 )
goto fail_alloc ;
2020-01-13 19:28:35 +03:00
nr = ( nr = = mlxplat_max_adap_num ) ? - 1 : nr ;
2019-06-23 15:16:25 +03:00
if ( mlxplat_i2c )
mlxplat_i2c - > regmap = priv - > regmap ;
priv - > pdev_i2c = platform_device_register_resndata (
& mlxplat_dev - > dev , " i2c_mlxcpld " ,
nr , mlxplat_mlxcpld_resources ,
ARRAY_SIZE ( mlxplat_mlxcpld_resources ) ,
mlxplat_i2c , sizeof ( * mlxplat_i2c ) ) ;
2016-09-23 00:13:42 +03:00
if ( IS_ERR ( priv - > pdev_i2c ) ) {
err = PTR_ERR ( priv - > pdev_i2c ) ;
goto fail_alloc ;
2016-10-27 20:26:50 +03:00
}
2016-09-23 00:13:42 +03:00
2020-01-13 19:28:35 +03:00
for ( i = 0 ; i < mlxplat_mux_num ; i + + ) {
2016-09-23 00:13:42 +03:00
priv - > pdev_mux [ i ] = platform_device_register_resndata (
platform/x86: mlx-platform: Fix parent device in i2c-mux-reg device registration
Fix the issue found while running kernel with the option
CONFIG_DEBUG_TEST_DRIVER_REMOVE.
Driver 'mlx-platform' registers 'i2c_mlxcpld' device and then registers
few underlying 'i2c-mux-reg' devices:
priv->pdev_i2c = platform_device_register_simple("i2c_mlxcpld", nr,
NULL, 0);
...
for (i = 0; i < ARRAY_SIZE(mlxplat_mux_data); i++) {
priv->pdev_mux[i] = platform_device_register_resndata(
&mlxplat_dev->dev,
"i2c-mux-reg", i, NULL,
0, &mlxplat_mux_data[i],
sizeof(mlxplat_mux_data[i]));
But actual parent of "i2c-mux-reg" device is priv->pdev_i2c->dev and
not mlxplat_dev->dev.
Patch fixes parent device parameter in a call to
platform_device_register_resndata() for "i2c-mux-reg".
It solves the race during initialization flow while 'i2c_mlxcpld.1' is
removing after probe, while 'i2c-mux-reg.0' is still in probing flow:
'i2c_mlxcpld.1' flow: probe -> remove -> probe.
'i2c-mux-reg.0' flow: probe -> ...
[ 12:621096] Registering platform device 'i2c_mlxcpld.1'. Parent at platform
[ 12:621117] device: 'i2c_mlxcpld.1': device_add
[ 12:621155] bus: 'platform': add device i2c_mlxcpld.1
[ 12:621384] Registering platform device 'i2c-mux-reg.0'. Parent at mlxplat
[ 12:621395] device: 'i2c-mux-reg.0': device_add
[ 12:621425] bus: 'platform': add device i2c-mux-reg.0
[ 12:621806] Registering platform device 'i2c-mux-reg.1'. Parent at mlxplat
[ 12:621828] device: 'i2c-mux-reg.1': device_add
[ 12:621892] bus: 'platform': add device i2c-mux-reg.1
[ 12:621906] bus: 'platform': add driver i2c_mlxcpld
[ 12:621996] bus: 'platform': driver_probe_device: matched device i2c_mlxcpld.1 with driver i2c_mlxcpld
[ 12:622003] bus: 'platform': really_probe: probing driver i2c_mlxcpld with device i2c_mlxcpld.1
[ 12:622100] i2c_mlxcpld i2c_mlxcpld.1: no default pinctrl state
[ 12:622293] device: 'i2c-1': device_add
[ 12:627280] bus: 'i2c': add device i2c-1
[ 12:627692] device: 'i2c-1': device_add
[ 12.629639] bus: 'platform': add driver i2c-mux-reg
[ 12.629718] bus: 'platform': driver_probe_device: matched device i2c-mux-reg.0 with driver i2c-mux-reg
[ 12.629723] bus: 'platform': really_probe: probing driver i2c-mux-reg with device i2c-mux-reg.0
[ 12.629818] i2c-mux-reg i2c-mux-reg.0: no default pinctrl state
[ 12.629981] platform i2c-mux-reg.0: Driver i2c-mux-reg requests probe deferral
[ 12.629986] platform i2c-mux-reg.0: Added to deferred list
[ 12.629992] bus: 'platform': driver_probe_device: matched device i2c-mux-reg.1 with driver i2c-mux-reg
[ 12.629997] bus: 'platform': really_probe: probing driver i2c-mux-reg with device i2c-mux-reg.1
[ 12.630091] i2c-mux-reg i2c-mux-reg.1: no default pinctrl state
[ 12.630247] platform i2c-mux-reg.1: Driver i2c-mux-reg requests probe deferral
[ 12.630252] platform i2c-mux-reg.1: Added to deferred list
[ 12.640892] devices_kset: Moving i2c-mux-reg.0 to end of list
[ 12.640900] platform i2c-mux-reg.0: Retrying from deferred list
[ 12.640911] bus: 'platform': driver_probe_device: matched device i2c-mux-reg.0 with driver i2c-mux-reg
[ 12.640919] bus: 'platform': really_probe: probing driver i2c-mux-reg with device i2c-mux-reg.0
[ 12.640999] i2c-mux-reg i2c-mux-reg.0: no default pinctrl state
[ 12.641177] platform i2c-mux-reg.0: Driver i2c-mux-reg requests probe deferral
[ 12.641187] platform i2c-mux-reg.0: Added to deferred list
[ 12.641198] devices_kset: Moving i2c-mux-reg.1 to end of list
[ 12.641219] platform i2c-mux-reg.1: Retrying from deferred list
[ 12.641237] bus: 'platform': driver_probe_device: matched device i2c-mux-reg.1 with driver i2c-mux-reg
[ 12.641247] bus: 'platform': really_probe: probing driver i2c-mux-reg with device i2c-mux-reg.1
[ 12.641331] i2c-mux-reg i2c-mux-reg.1: no default pinctrl state
[ 12.641465] platform i2c-mux-reg.1: Driver i2c-mux-reg requests probe deferral
[ 12.641469] platform i2c-mux-reg.1: Added to deferred list
[ 12.646427] device: 'i2c-1': device_add
[ 12.646647] bus: 'i2c': add device i2c-1
[ 12.647104] device: 'i2c-1': device_add
[ 12.669231] devices_kset: Moving i2c-mux-reg.0 to end of list
[ 12.669240] platform i2c-mux-reg.0: Retrying from deferred list
[ 12.669258] bus: 'platform': driver_probe_device: matched device i2c-mux-reg.0 with driver i2c-mux-reg
[ 12.669263] bus: 'platform': really_probe: probing driver i2c-mux-reg with device i2c-mux-reg.0
[ 12.669343] i2c-mux-reg i2c-mux-reg.0: no default pinctrl state
[ 12.669585] device: 'i2c-2': device_add
[ 12.669795] bus: 'i2c': add device i2c-2
[ 12.670201] device: 'i2c-2': device_add
[ 12.671427] i2c i2c-1: Added multiplexed i2c bus 2
[ 12.671514] device: 'i2c-3': device_add
[ 12.671724] bus: 'i2c': add device i2c-3
[ 12.672136] device: 'i2c-3': device_add
[ 12.673378] i2c i2c-1: Added multiplexed i2c bus 3
[ 12.673472] device: 'i2c-4': device_add
[ 12.673676] bus: 'i2c': add device i2c-4
[ 12.674060] device: 'i2c-4': device_add
[ 12.675861] i2c i2c-1: Added multiplexed i2c bus 4
[ 12.675941] device: 'i2c-5': device_add
[ 12.676150] bus: 'i2c': add device i2c-5
[ 12.676550] device: 'i2c-5': device_add
[ 12.678103] i2c i2c-1: Added multiplexed i2c bus 5
[ 12.678193] device: 'i2c-6': device_add
[ 12.678395] bus: 'i2c': add device i2c-6
[ 12.678774] device: 'i2c-6': device_add
[ 12.679969] i2c i2c-1: Added multiplexed i2c bus 6
[ 12.680065] device: 'i2c-7': device_add
[ 12.680275] bus: 'i2c': add device i2c-7
[ 12.680913] device: 'i2c-7': device_add
[ 12.682506] i2c i2c-1: Added multiplexed i2c bus 7
[ 12.682600] device: 'i2c-8': device_add
[ 12.682808] bus: 'i2c': add device i2c-8
[ 12.683189] device: 'i2c-8': device_add
[ 12.683907] device: 'i2c-1': device_unregister
[ 12.683945] device: 'i2c-1': device_unregister
[ 12.684387] device: 'i2c-1': device_create_release
[ 12.684536] bus: 'i2c': remove device i2c-1
[ 12.686019] i2c i2c-8: Failed to create compatibility class link
[ 12.686086] ------------[ cut here ]------------
[ 12.686087] can't create symlink to mux device
[ 12.686224] Workqueue: events deferred_probe_work_func
[ 12.686135] WARNING: CPU: 7 PID: 436 at drivers/i2c/i2c-mux.c:416 i2c_mux_add_adapter+0x729/0x7d0 [i2c_mux]
[ 12.686232] RIP: 0010:i2c_mux_add_adapter+0x729/0x7d0 [i2c_mux]
[ 0x190/0x190 [i2c_mux]
[ 12.686300] ? i2c_mux_alloc+0xac/0x110 [i2c_mux]
[ 12.686306] ? i2c_mux_reg_set+0x200/0x200 [i2c_mux_reg]
[ 12.686313] i2c_mux_reg_probe+0x22c/0x731 [i2c_mux_reg]
[ 12.686322] ? i2c_mux_reg_deselect+0x60/0x60 [i2c_mux_reg]
[ 12.686346] platform_drv_probe+0xa8/0x110
[ 12.686351] really_probe+0x185/0x720
[ 12.686358] driver_probe_device+0xdf/0x1f0
...
[ 12.686522] i2c i2c-1: Added multiplexed i2c bus 8
[ 12.686621] device: 'i2c-9': device_add
[ 12.686626] kobject_add_internal failed for i2c-9 (error: -2 parent: i2c-1)
[ 12.694729] i2c-core: adapter 'i2c-1-mux (chan_id 8)': can't register device (-2)
[ 12.705726] i2c i2c-1: failed to add mux-adapter 8 as bus 9 (error=-2)
[ 12.714494] device: 'i2c-8': device_unregister
[ 12.714537] device: 'i2c-8': device_unregister
Fixes: 6613d18e9038 ("platform/x86: mlx-platform: Move module from arch/x86")
Signed-off-by: Vadim Pasternak <vadimp@mellanox.com>
Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
2019-06-05 10:51:03 +03:00
& priv - > pdev_i2c - > dev ,
2016-09-23 00:13:42 +03:00
" i2c-mux-reg " , i , NULL ,
0 , & mlxplat_mux_data [ i ] ,
sizeof ( mlxplat_mux_data [ i ] ) ) ;
if ( IS_ERR ( priv - > pdev_mux [ i ] ) ) {
err = PTR_ERR ( priv - > pdev_mux [ i ] ) ;
goto fail_platform_mux_register ;
}
}
2019-06-23 15:16:24 +03:00
/* Add hotplug driver */
mlxplat_hotplug - > regmap = priv - > regmap ;
2016-10-27 22:55:54 +03:00
priv - > pdev_hotplug = platform_device_register_resndata (
2018-01-17 21:21:53 +03:00
& mlxplat_dev - > dev , " mlxreg-hotplug " ,
2016-12-14 15:05:15 +03:00
PLATFORM_DEVID_NONE ,
mlxplat_mlxcpld_resources ,
ARRAY_SIZE ( mlxplat_mlxcpld_resources ) ,
2016-10-27 22:55:54 +03:00
mlxplat_hotplug , sizeof ( * mlxplat_hotplug ) ) ;
if ( IS_ERR ( priv - > pdev_hotplug ) ) {
err = PTR_ERR ( priv - > pdev_hotplug ) ;
goto fail_platform_mux_register ;
}
2018-06-17 19:56:54 +03:00
/* Set default registers. */
2019-06-23 15:16:24 +03:00
for ( j = 0 ; j < mlxplat_regmap_config - > num_reg_defaults ; j + + ) {
err = regmap_write ( priv - > regmap ,
mlxplat_regmap_config - > reg_defaults [ j ] . reg ,
mlxplat_regmap_config - > reg_defaults [ j ] . def ) ;
2018-06-17 19:56:54 +03:00
if ( err )
goto fail_platform_mux_register ;
}
2018-05-07 09:48:53 +03:00
/* Add LED driver. */
2019-06-23 15:16:24 +03:00
mlxplat_led - > regmap = priv - > regmap ;
2018-05-07 09:48:53 +03:00
priv - > pdev_led = platform_device_register_resndata (
& mlxplat_dev - > dev , " leds-mlxreg " ,
PLATFORM_DEVID_NONE , NULL , 0 ,
mlxplat_led , sizeof ( * mlxplat_led ) ) ;
if ( IS_ERR ( priv - > pdev_led ) ) {
err = PTR_ERR ( priv - > pdev_led ) ;
goto fail_platform_hotplug_register ;
}
2018-06-17 19:56:54 +03:00
/* Add registers io access driver. */
if ( mlxplat_regs_io ) {
2019-06-23 15:16:24 +03:00
mlxplat_regs_io - > regmap = priv - > regmap ;
2018-06-17 19:56:54 +03:00
priv - > pdev_io_regs = platform_device_register_resndata (
& mlxplat_dev - > dev , " mlxreg-io " ,
PLATFORM_DEVID_NONE , NULL , 0 ,
mlxplat_regs_io ,
sizeof ( * mlxplat_regs_io ) ) ;
if ( IS_ERR ( priv - > pdev_io_regs ) ) {
err = PTR_ERR ( priv - > pdev_io_regs ) ;
goto fail_platform_led_register ;
}
}
2018-07-27 01:40:57 +03:00
/* Add FAN driver. */
if ( mlxplat_fan ) {
2019-06-23 15:16:24 +03:00
mlxplat_fan - > regmap = priv - > regmap ;
2018-07-27 01:40:57 +03:00
priv - > pdev_fan = platform_device_register_resndata (
& mlxplat_dev - > dev , " mlxreg-fan " ,
PLATFORM_DEVID_NONE , NULL , 0 ,
mlxplat_fan ,
sizeof ( * mlxplat_fan ) ) ;
2018-08-08 07:00:30 +03:00
if ( IS_ERR ( priv - > pdev_fan ) ) {
err = PTR_ERR ( priv - > pdev_fan ) ;
2018-07-27 01:40:57 +03:00
goto fail_platform_io_regs_register ;
}
}
2019-03-18 13:58:23 +03:00
/* Add WD drivers. */
for ( j = 0 ; j < MLXPLAT_CPLD_WD_MAX_DEVS ; j + + ) {
if ( mlxplat_wd_data [ j ] ) {
2019-06-23 15:16:24 +03:00
mlxplat_wd_data [ j ] - > regmap = priv - > regmap ;
2019-03-18 13:58:23 +03:00
priv - > pdev_wd [ j ] = platform_device_register_resndata (
& mlxplat_dev - > dev , " mlx-wdt " ,
j , NULL , 0 ,
mlxplat_wd_data [ j ] ,
sizeof ( * mlxplat_wd_data [ j ] ) ) ;
if ( IS_ERR ( priv - > pdev_wd [ j ] ) ) {
err = PTR_ERR ( priv - > pdev_wd [ j ] ) ;
goto fail_platform_wd_register ;
}
}
}
2018-01-26 22:03:44 +03:00
/* Sync registers with hardware. */
2019-06-23 15:16:24 +03:00
regcache_mark_dirty ( priv - > regmap ) ;
err = regcache_sync ( priv - > regmap ) ;
2018-01-26 22:03:44 +03:00
if ( err )
2019-03-18 13:58:23 +03:00
goto fail_platform_wd_register ;
2018-01-26 22:03:44 +03:00
2016-09-23 00:13:42 +03:00
return 0 ;
2019-03-18 13:58:23 +03:00
fail_platform_wd_register :
while ( - - j > = 0 )
platform_device_unregister ( priv - > pdev_wd [ j ] ) ;
2018-07-27 01:40:57 +03:00
if ( mlxplat_fan )
platform_device_unregister ( priv - > pdev_fan ) ;
2018-06-17 19:56:54 +03:00
fail_platform_io_regs_register :
if ( mlxplat_regs_io )
platform_device_unregister ( priv - > pdev_io_regs ) ;
2018-05-07 09:48:53 +03:00
fail_platform_led_register :
platform_device_unregister ( priv - > pdev_led ) ;
2018-02-01 00:55:13 +03:00
fail_platform_hotplug_register :
platform_device_unregister ( priv - > pdev_hotplug ) ;
2016-09-23 00:13:42 +03:00
fail_platform_mux_register :
2017-01-07 09:33:34 +03:00
while ( - - i > = 0 )
2016-09-23 00:13:42 +03:00
platform_device_unregister ( priv - > pdev_mux [ i ] ) ;
platform_device_unregister ( priv - > pdev_i2c ) ;
fail_alloc :
platform_device_unregister ( mlxplat_dev ) ;
return err ;
}
module_init ( mlxplat_init ) ;
static void __exit mlxplat_exit ( void )
{
struct mlxplat_priv * priv = platform_get_drvdata ( mlxplat_dev ) ;
int i ;
2019-03-18 13:58:23 +03:00
for ( i = MLXPLAT_CPLD_WD_MAX_DEVS - 1 ; i > = 0 ; i - - )
platform_device_unregister ( priv - > pdev_wd [ i ] ) ;
2018-07-27 01:40:57 +03:00
if ( priv - > pdev_fan )
platform_device_unregister ( priv - > pdev_fan ) ;
2018-06-17 19:56:54 +03:00
if ( priv - > pdev_io_regs )
platform_device_unregister ( priv - > pdev_io_regs ) ;
2018-05-07 09:48:53 +03:00
platform_device_unregister ( priv - > pdev_led ) ;
2016-10-27 22:55:54 +03:00
platform_device_unregister ( priv - > pdev_hotplug ) ;
2020-01-13 19:28:35 +03:00
for ( i = mlxplat_mux_num - 1 ; i > = 0 ; i - - )
2016-09-23 00:13:42 +03:00
platform_device_unregister ( priv - > pdev_mux [ i ] ) ;
platform_device_unregister ( priv - > pdev_i2c ) ;
platform_device_unregister ( mlxplat_dev ) ;
}
module_exit ( mlxplat_exit ) ;
MODULE_AUTHOR ( " Vadim Pasternak (vadimp@mellanox.com) " ) ;
MODULE_DESCRIPTION ( " Mellanox platform driver " ) ;
MODULE_LICENSE ( " Dual BSD/GPL " ) ;