253
253
#define MLXPLAT_CPLD_CH3_ETH_MODULAR 43
254
254
#define MLXPLAT_CPLD_CH4_ETH_MODULAR 51
255
255
#define MLXPLAT_CPLD_CH2_RACK_SWITCH 18
256
+ #define MLXPLAT_CPLD_CH2_NG800 34
256
257
257
258
/* Number of LPC attached MUX platform devices */
258
259
#define MLXPLAT_CPLD_LPC_MUX_DEVS 4
@@ -503,6 +504,37 @@ static struct i2c_mux_reg_platform_data mlxplat_rack_switch_mux_data[] = {
503
504
504
505
};
505
506
507
+ /* Platform channels for ng800 system family */
508
+ static const int mlxplat_ng800_channels [] = {
509
+ 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 17 ,
510
+ 18 , 19 , 20 , 21 , 22 , 23 , 24 , 25 , 26 , 27 , 28 , 29 , 30 , 31 , 32
511
+ };
512
+
513
+ /* Platform ng800 mux data */
514
+ static struct i2c_mux_reg_platform_data mlxplat_ng800_mux_data [] = {
515
+ {
516
+ .parent = 1 ,
517
+ .base_nr = MLXPLAT_CPLD_CH1 ,
518
+ .write_only = 1 ,
519
+ .reg = (void __iomem * )MLXPLAT_CPLD_LPC_REG1 ,
520
+ .reg_size = 1 ,
521
+ .idle_in_use = 1 ,
522
+ .values = mlxplat_ng800_channels ,
523
+ .n_values = ARRAY_SIZE (mlxplat_ng800_channels ),
524
+ },
525
+ {
526
+ .parent = 1 ,
527
+ .base_nr = MLXPLAT_CPLD_CH2_NG800 ,
528
+ .write_only = 1 ,
529
+ .reg = (void __iomem * )MLXPLAT_CPLD_LPC_REG2 ,
530
+ .reg_size = 1 ,
531
+ .idle_in_use = 1 ,
532
+ .values = mlxplat_msn21xx_channels ,
533
+ .n_values = ARRAY_SIZE (mlxplat_msn21xx_channels ),
534
+ },
535
+
536
+ };
537
+
506
538
/* Platform hotplug devices */
507
539
static struct i2c_board_info mlxplat_mlxcpld_pwr [] = {
508
540
{
@@ -522,6 +554,15 @@ static struct i2c_board_info mlxplat_mlxcpld_ext_pwr[] = {
522
554
},
523
555
};
524
556
557
+ static struct i2c_board_info mlxplat_mlxcpld_pwr_ng800 [] = {
558
+ {
559
+ I2C_BOARD_INFO ("dps460" , 0x59 ),
560
+ },
561
+ {
562
+ I2C_BOARD_INFO ("dps460" , 0x5a ),
563
+ },
564
+ };
565
+
525
566
static struct i2c_board_info mlxplat_mlxcpld_fan [] = {
526
567
{
527
568
I2C_BOARD_INFO ("24c32" , 0x50 ),
@@ -601,6 +642,23 @@ static struct mlxreg_core_data mlxplat_mlxcpld_default_pwr_wc_items_data[] = {
601
642
},
602
643
};
603
644
645
+ static struct mlxreg_core_data mlxplat_mlxcpld_default_pwr_ng800_items_data [] = {
646
+ {
647
+ .label = "pwr1" ,
648
+ .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET ,
649
+ .mask = BIT (0 ),
650
+ .hpdev .brdinfo = & mlxplat_mlxcpld_pwr_ng800 [0 ],
651
+ .hpdev .nr = MLXPLAT_CPLD_PSU_MSNXXXX_NR ,
652
+ },
653
+ {
654
+ .label = "pwr2" ,
655
+ .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET ,
656
+ .mask = BIT (1 ),
657
+ .hpdev .brdinfo = & mlxplat_mlxcpld_pwr_ng800 [1 ],
658
+ .hpdev .nr = MLXPLAT_CPLD_PSU_MSNXXXX_NR ,
659
+ },
660
+ };
661
+
604
662
static struct mlxreg_core_data mlxplat_mlxcpld_default_fan_items_data [] = {
605
663
{
606
664
.label = "fan1" ,
@@ -1224,6 +1282,47 @@ static struct mlxreg_core_item mlxplat_mlxcpld_ext_items[] = {
1224
1282
}
1225
1283
};
1226
1284
1285
+ static struct mlxreg_core_item mlxplat_mlxcpld_ng800_items [] = {
1286
+ {
1287
+ .data = mlxplat_mlxcpld_default_ng_psu_items_data ,
1288
+ .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF ,
1289
+ .reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET ,
1290
+ .mask = MLXPLAT_CPLD_PSU_EXT_MASK ,
1291
+ .capability = MLXPLAT_CPLD_LPC_REG_PSU_I2C_CAP_OFFSET ,
1292
+ .count = ARRAY_SIZE (mlxplat_mlxcpld_default_ng_psu_items_data ),
1293
+ .inversed = 1 ,
1294
+ .health = false,
1295
+ },
1296
+ {
1297
+ .data = mlxplat_mlxcpld_default_pwr_ng800_items_data ,
1298
+ .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF ,
1299
+ .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET ,
1300
+ .mask = MLXPLAT_CPLD_PWR_EXT_MASK ,
1301
+ .capability = MLXPLAT_CPLD_LPC_REG_PSU_I2C_CAP_OFFSET ,
1302
+ .count = ARRAY_SIZE (mlxplat_mlxcpld_default_pwr_ng800_items_data ),
1303
+ .inversed = 0 ,
1304
+ .health = false,
1305
+ },
1306
+ {
1307
+ .data = mlxplat_mlxcpld_default_ng_fan_items_data ,
1308
+ .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF ,
1309
+ .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET ,
1310
+ .mask = MLXPLAT_CPLD_FAN_NG_MASK ,
1311
+ .count = ARRAY_SIZE (mlxplat_mlxcpld_default_ng_fan_items_data ),
1312
+ .inversed = 1 ,
1313
+ .health = false,
1314
+ },
1315
+ {
1316
+ .data = mlxplat_mlxcpld_default_asic_items_data ,
1317
+ .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF ,
1318
+ .reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET ,
1319
+ .mask = MLXPLAT_CPLD_ASIC_MASK ,
1320
+ .count = ARRAY_SIZE (mlxplat_mlxcpld_default_asic_items_data ),
1321
+ .inversed = 0 ,
1322
+ .health = true,
1323
+ },
1324
+ };
1325
+
1227
1326
static
1228
1327
struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_ext_data = {
1229
1328
.items = mlxplat_mlxcpld_ext_items ,
@@ -1234,6 +1333,16 @@ struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_ext_data = {
1234
1333
.mask_low = MLXPLAT_CPLD_LOW_AGGR_MASK_LOW | MLXPLAT_CPLD_LOW_AGGR_MASK_ASIC2 ,
1235
1334
};
1236
1335
1336
+ static
1337
+ struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_ng800_data = {
1338
+ .items = mlxplat_mlxcpld_ng800_items ,
1339
+ .counter = ARRAY_SIZE (mlxplat_mlxcpld_ng800_items ),
1340
+ .cell = MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET ,
1341
+ .mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF | MLXPLAT_CPLD_AGGR_MASK_COMEX ,
1342
+ .cell_low = MLXPLAT_CPLD_LPC_REG_AGGRLO_OFFSET ,
1343
+ .mask_low = MLXPLAT_CPLD_LOW_AGGR_MASK_LOW | MLXPLAT_CPLD_LOW_AGGR_MASK_ASIC2 ,
1344
+ };
1345
+
1237
1346
static struct mlxreg_core_data mlxplat_mlxcpld_modular_pwr_items_data [] = {
1238
1347
{
1239
1348
.label = "pwr1" ,
@@ -3093,6 +3202,13 @@ static struct mlxreg_core_data mlxplat_mlxcpld_default_ng_regs_io_data[] = {
3093
3202
.mask = GENMASK (7 , 0 ) & ~BIT (7 ),
3094
3203
.mode = 0644 ,
3095
3204
},
3205
+ {
3206
+ .label = "clk_brd_prog_en" ,
3207
+ .reg = MLXPLAT_CPLD_LPC_REG_PWM_CONTROL_OFFSET ,
3208
+ .mask = GENMASK (7 , 0 ) & ~BIT (1 ),
3209
+ .mode = 0644 ,
3210
+ .secured = 1 ,
3211
+ },
3096
3212
{
3097
3213
.label = "erot1_recovery" ,
3098
3214
.reg = MLXPLAT_CPLD_LPC_REG_PWM_CONTROL_OFFSET ,
@@ -3221,6 +3337,12 @@ static struct mlxreg_core_data mlxplat_mlxcpld_default_ng_regs_io_data[] = {
3221
3337
.mask = GENMASK (7 , 0 ) & ~BIT (6 ),
3222
3338
.mode = 0444 ,
3223
3339
},
3340
+ {
3341
+ .label = "reset_ac_ok_fail" ,
3342
+ .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET ,
3343
+ .mask = GENMASK (7 , 0 ) & ~BIT (7 ),
3344
+ .mode = 0444 ,
3345
+ },
3224
3346
{
3225
3347
.label = "psu1_on" ,
3226
3348
.reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET ,
@@ -3302,6 +3424,13 @@ static struct mlxreg_core_data mlxplat_mlxcpld_default_ng_regs_io_data[] = {
3302
3424
.bit = 5 ,
3303
3425
.mode = 0444 ,
3304
3426
},
3427
+ {
3428
+ .label = "pwr_converter_prog_en" ,
3429
+ .reg = MLXPLAT_CPLD_LPC_REG_GP0_OFFSET ,
3430
+ .mask = GENMASK (7 , 0 ) & ~BIT (0 ),
3431
+ .mode = 0644 ,
3432
+ .secured = 1 ,
3433
+ },
3305
3434
{
3306
3435
.label = "vpd_wp" ,
3307
3436
.reg = MLXPLAT_CPLD_LPC_REG_GP0_OFFSET ,
@@ -3326,6 +3455,30 @@ static struct mlxreg_core_data mlxplat_mlxcpld_default_ng_regs_io_data[] = {
3326
3455
.mask = GENMASK (7 , 0 ) & ~BIT (1 ),
3327
3456
.mode = 0444 ,
3328
3457
},
3458
+ {
3459
+ .label = "clk_brd1_boot_fail" ,
3460
+ .reg = MLXPLAT_CPLD_LPC_REG_GP4_RO_OFFSET ,
3461
+ .mask = GENMASK (7 , 0 ) & ~BIT (4 ),
3462
+ .mode = 0444 ,
3463
+ },
3464
+ {
3465
+ .label = "clk_brd2_boot_fail" ,
3466
+ .reg = MLXPLAT_CPLD_LPC_REG_GP4_RO_OFFSET ,
3467
+ .mask = GENMASK (7 , 0 ) & ~BIT (5 ),
3468
+ .mode = 0444 ,
3469
+ },
3470
+ {
3471
+ .label = "clk_brd_fail" ,
3472
+ .reg = MLXPLAT_CPLD_LPC_REG_GP4_RO_OFFSET ,
3473
+ .mask = GENMASK (7 , 0 ) & ~BIT (6 ),
3474
+ .mode = 0444 ,
3475
+ },
3476
+ {
3477
+ .label = "asic_pg_fail" ,
3478
+ .reg = MLXPLAT_CPLD_LPC_REG_GP4_RO_OFFSET ,
3479
+ .mask = GENMASK (7 , 0 ) & ~BIT (7 ),
3480
+ .mode = 0444 ,
3481
+ },
3329
3482
{
3330
3483
.label = "spi_chnl_select" ,
3331
3484
.reg = MLXPLAT_CPLD_LPC_REG_SPI_CHNL_SELECT ,
@@ -5211,6 +5364,27 @@ static int __init mlxplat_dmi_rack_switch_matched(const struct dmi_system_id *dm
5211
5364
return 1 ;
5212
5365
}
5213
5366
5367
+ static int __init mlxplat_dmi_ng800_matched (const struct dmi_system_id * dmi )
5368
+ {
5369
+ int i ;
5370
+
5371
+ mlxplat_max_adap_num = MLXPLAT_CPLD_MAX_PHYS_ADAPTER_NUM ;
5372
+ mlxplat_mux_num = ARRAY_SIZE (mlxplat_ng800_mux_data );
5373
+ mlxplat_mux_data = mlxplat_ng800_mux_data ;
5374
+ mlxplat_hotplug = & mlxplat_mlxcpld_ng800_data ;
5375
+ mlxplat_hotplug -> deferred_nr =
5376
+ mlxplat_msn21xx_channels [MLXPLAT_CPLD_GRP_CHNL_NUM - 1 ];
5377
+ mlxplat_led = & mlxplat_default_ng_led_data ;
5378
+ mlxplat_regs_io = & mlxplat_default_ng_regs_io_data ;
5379
+ mlxplat_fan = & mlxplat_default_fan_data ;
5380
+ for (i = 0 ; i < ARRAY_SIZE (mlxplat_mlxcpld_wd_set_type2 ); i ++ )
5381
+ mlxplat_wd_data [i ] = & mlxplat_mlxcpld_wd_set_type2 [i ];
5382
+ mlxplat_i2c = & mlxplat_mlxcpld_i2c_ng_data ;
5383
+ mlxplat_regmap_config = & mlxplat_mlxcpld_regmap_config_ng400 ;
5384
+
5385
+ return 1 ;
5386
+ }
5387
+
5214
5388
static const struct dmi_system_id mlxplat_dmi_table [] __initconst = {
5215
5389
{
5216
5390
.callback = mlxplat_dmi_default_wc_matched ,
@@ -5287,6 +5461,12 @@ static const struct dmi_system_id mlxplat_dmi_table[] __initconst = {
5287
5461
DMI_MATCH (DMI_BOARD_NAME , "VMOD0011" ),
5288
5462
},
5289
5463
},
5464
+ {
5465
+ .callback = mlxplat_dmi_ng800_matched ,
5466
+ .matches = {
5467
+ DMI_MATCH (DMI_BOARD_NAME , "VMOD0013" ),
5468
+ },
5469
+ },
5290
5470
{
5291
5471
.callback = mlxplat_dmi_chassis_blade_matched ,
5292
5472
.matches = {
0 commit comments