sonic-buildimage/platform/innovium/sonic-platform-modules-cameo/esc602-32q/modules/x86-64-cameo-esc602-32q-sys.c
shihjeff 940aaa0cbe
[201911] [Innovium] Update Cameo & Wistron Drivers (#7855)
Fix #8068

Update Innovium configs on Cameo and Wistron platforms
2021-07-21 09:09:36 -07:00

789 lines
23 KiB
C

/* An hwmon driver for Cameo esc602-32Q Innovium i2c Module */
#pragma GCC diagnostic ignored "-Wformat-zero-length"
#include "x86-64-cameo-esc602-32q.h"
#include "x86-64-cameo-esc602-32q-common.h"
#include "x86-64-cameo-esc602-32q-sys.h"
/* extern i2c_client */
extern struct i2c_client *Cameo_CPLD_30_client; //0x30 for SYS CPLD
extern struct i2c_client *Cameo_CPLD_31_client; //0x31 for Port 01-16
extern struct i2c_client *Cameo_CPLD_32_client; //0x32 for Port 17-32
extern struct i2c_client *Cameo_CPLD_23_client; //0x23 for Fan CPLD
extern struct i2c_client *Cameo_BMC_14_client; //0x14 for BMC slave
/* end of extern i2c_client */
/* implement i2c_function */
ssize_t cpld_hw_ver_get(struct device *dev, struct device_attribute *da, char *buf)
{
int status = -EPERM;
struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
struct Cameo_i2c_data *data = i2c_get_clientdata(Cameo_CPLD_30_client);
mutex_lock(&data->update_lock);
sprintf(buf, "");
switch (attr->index)
{
case 23:
if( bmc_enable() == ENABLE)
{
status = i2c_smbus_read_byte_data(Cameo_BMC_14_client, 0xff);
}
else
{
status = i2c_smbus_read_byte_data(Cameo_CPLD_23_client, CPLD_VER_REG);
}
break;
case 30:
status = i2c_smbus_read_byte_data(Cameo_CPLD_30_client, CPLD_VER_REG);
break;
case 31:
status = i2c_smbus_read_byte_data(Cameo_CPLD_31_client, CPLD_VER_REG);
break;
case 32:
status = i2c_smbus_read_byte_data(Cameo_CPLD_32_client, CPLD_VER_REG);
break;
}
if(status < 0)
{
mutex_unlock(&data->update_lock);
return status;
}
else
{
mutex_unlock(&data->update_lock);
sprintf(buf, "%s0x%x\n", buf, status);
}
return sprintf(buf, "%s\n", buf);
}
ssize_t wdt_enable_get(struct device *dev, struct device_attribute *da, char *buf)
{
struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
struct Cameo_i2c_data *data = i2c_get_clientdata(Cameo_CPLD_30_client);
mutex_lock(&data->update_lock);
sprintf(buf, "");
if (attr->index == WDT_EN)
{
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, WDT_EN_REG) & BIT_4_MASK)
{
sprintf(buf, "%s%d\n", buf, ENABLE);
}
else
{
sprintf(buf, "%s%d\n", buf, DISABLE);
}
}
mutex_unlock(&data->update_lock);
return sprintf(buf, "%s\n", buf);
}
ssize_t wdt_enable_set(struct device *dev, struct device_attribute *da, const char *buf, size_t count)
{
int status = -EPERM;
int value = -EPERM;
int result = -EPERM;
int input;
struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
struct Cameo_i2c_data *data = i2c_get_clientdata(Cameo_CPLD_30_client);
mutex_lock(&data->update_lock);
status = i2c_smbus_read_byte_data(Cameo_CPLD_30_client, WDT_EN_REG);
if (attr->index == WDT_EN)
{
input = simple_strtol(buf, NULL, 10);
if (input == ENABLE)
{
value = status | WDT_EN_ENABLE;
result = i2c_smbus_write_byte_data(Cameo_CPLD_30_client, WDT_EN_REG, value);
if (result < 0)
{
printk(KERN_ALERT "ERROR: wdt_enable_set FAILED!\n");
}
}
else if (input == DISABLE)
{
value = status & WDT_EN_DISABLE;
result = i2c_smbus_write_byte_data(Cameo_CPLD_30_client, WDT_EN_REG, value);
if (result < 0)
{
printk(KERN_ALERT "ERROR: wdt_enable_set FAILED!\n");
}
}
else
{
printk(KERN_ALERT "wdt_enable_set wrong Value\n");
}
}
mutex_unlock(&data->update_lock);
return count;
}
ssize_t eeprom_wp_get(struct device *dev, struct device_attribute *da, char *buf)
{
struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
struct Cameo_i2c_data *data = i2c_get_clientdata(Cameo_CPLD_30_client);
mutex_lock(&data->update_lock);
sprintf(buf, "");
if (attr->index == EEPROM_WP)
{
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, EEPROM_WP_REG) & BIT_2_MASK)
{
sprintf(buf, "%s%d\n", buf, ENABLE);
}
else
{
sprintf(buf, "%s%d\n", buf, DISABLE);
}
}
mutex_unlock(&data->update_lock);
return sprintf(buf, "%s\n", buf);
}
ssize_t eeprom_wp_set(struct device *dev, struct device_attribute *da, const char *buf, size_t count)
{
int status = -EPERM;
int value = -EPERM;
int result = -EPERM;
int input;
struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
struct Cameo_i2c_data *data = i2c_get_clientdata(Cameo_CPLD_30_client);
mutex_lock(&data->update_lock);
status = i2c_smbus_read_byte_data(Cameo_CPLD_30_client, EEPROM_WP_REG);
if (attr->index == EEPROM_WP)
{
input = simple_strtol(buf, NULL, 10);
if (input == ENABLE)
{
value = status | EEPROM_WP_ENABLE;
result = i2c_smbus_write_byte_data(Cameo_CPLD_30_client, EEPROM_WP_REG, value);
if (result < 0)
{
printk(KERN_ALERT "ERROR: eeprom_wp_set FAILED!\n");
}
}
else if (input == DISABLE)
{
value = status & EEPROM_WP_DISABLE;
result = i2c_smbus_write_byte_data(Cameo_CPLD_30_client, EEPROM_WP_REG, value);
if (result < 0)
{
printk(KERN_ALERT "ERROR: eeprom_wp_set FAILED!\n");
}
}
else
{
printk(KERN_ALERT "eeprom_wp_set wrong Value\n");
}
}
mutex_unlock(&data->update_lock);
return count;
}
ssize_t usb_enable_get(struct device *dev, struct device_attribute *da, char *buf)
{
struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
struct Cameo_i2c_data *data = i2c_get_clientdata(Cameo_CPLD_30_client);
mutex_lock(&data->update_lock);
sprintf(buf, "");
if (attr->index == USB_EN)
{
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, USB_EN_REG) & BIT_1_MASK)
{
sprintf(buf, "%s%d\n", buf, ENABLE);
}
else
{
sprintf(buf, "%s%d\n", buf, DISABLE);
}
}
mutex_unlock(&data->update_lock);
return sprintf(buf, "%s\n", buf);
}
ssize_t usb_enable_set(struct device *dev, struct device_attribute *da, const char *buf, size_t count)
{
int status = -EPERM;
int value = -EPERM;
int result = -EPERM;
int input;
struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
struct Cameo_i2c_data *data = i2c_get_clientdata(Cameo_CPLD_30_client);
mutex_lock(&data->update_lock);
status = i2c_smbus_read_byte_data(Cameo_CPLD_30_client, USB_EN_REG);
if (attr->index == USB_EN)
{
input = simple_strtol(buf, NULL, 10);
if (input == ENABLE)
{
value = status | USB_EN_ENABLE;
result = i2c_smbus_write_byte_data(Cameo_CPLD_30_client, USB_EN_REG, value);
if (result < 0)
{
printk(KERN_ALERT "ERROR: usb_enable_set FAILED!\n");
}
}
else if (input == DISABLE)
{
value = status & USB_EN_DISABLE;
result = i2c_smbus_write_byte_data(Cameo_CPLD_30_client, USB_EN_REG, value);
if (result < 0)
{
printk(KERN_ALERT "ERROR: usb_enable_set FAILED!\n");
}
}
else
{
printk(KERN_ALERT "usb_enable_set wrong Value\n");
}
}
mutex_unlock(&data->update_lock);
return count;
}
ssize_t reset_mac_set(struct device *dev, struct device_attribute *da, const char *buf, size_t count)
{
int status = -EPERM;
int value = -EPERM;
int result = -EPERM;
int input;
struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
struct Cameo_i2c_data *data = i2c_get_clientdata(Cameo_CPLD_30_client);
mutex_lock(&data->update_lock);
status = i2c_smbus_read_byte_data(Cameo_CPLD_30_client, MAC_RESET_REG);
if (attr->index == RESET)
{
input = simple_strtol(buf, NULL, 10);
if (input == MAC_RESET)
{
value = MAC_RESET;
result = i2c_smbus_write_byte_data(Cameo_CPLD_30_client, MAC_RESET_REG, value);
if (result < 0)
{
printk(KERN_ALERT "ERROR: reset_mac_set FAILED!\n");
}
}
else
{
printk(KERN_ALERT "reset_mac_set wrong Value\n");
}
}
mutex_unlock(&data->update_lock);
return count;
}
ssize_t shutdown_set(struct device *dev, struct device_attribute *da, const char *buf, size_t count)
{
int status = -EPERM;
int value = -EPERM;
int result = -EPERM;
int input;
struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
struct Cameo_i2c_data *data = i2c_get_clientdata(Cameo_CPLD_30_client);
mutex_lock(&data->update_lock);
status = i2c_smbus_read_byte_data(Cameo_CPLD_30_client, SHUTDOWN_REG);
if (attr->index == SHUTDOWN_SET)
{
input = simple_strtol(buf, NULL, 10);
if (input == SHUTDOWN)
{
value = status | SHUTDOWN;
result = i2c_smbus_write_byte_data(Cameo_CPLD_30_client, SHUTDOWN_REG, value);
if (result < 0)
{
printk(KERN_ALERT "ERROR: shutdown_set FAILED!\n");
}
}
else
{
printk(KERN_ALERT "shutdown_set wrong Value\n");
}
}
mutex_unlock(&data->update_lock);
return count;
}
ssize_t bmc_enable_get(struct device *dev, struct device_attribute *da, char *buf)
{
struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
struct Cameo_i2c_data *data = i2c_get_clientdata(Cameo_CPLD_30_client);
mutex_lock(&data->update_lock);
sprintf(buf, "");
if (attr->index == BMC_PRESENT)
{
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, BMC_EN_REG) & BIT_0_MASK)
{
sprintf(buf, "%s%d\n", buf, ENABLE);
}
else
{
sprintf(buf, "%s%d\n", buf, DISABLE);
}
}
mutex_unlock(&data->update_lock);
return sprintf(buf, "%s\n", buf);
}
ssize_t themal_int_get(struct device *dev, struct device_attribute *da, char *buf)
{
int result = 0;
struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
struct Cameo_i2c_data *data = i2c_get_clientdata(Cameo_CPLD_30_client);
mutex_lock(&data->update_lock);
sprintf(buf, "");
switch (attr->index)
{
case TEMP_R_B_INT:
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, THERMAL_INT_REG) & BIT_0_MASK)
{
result = ENABLE;
}
else
{
result = DISABLE;
}
break;
case TEMP_L_B_INT:
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, THERMAL_INT_REG) & BIT_1_MASK)
{
result = ENABLE;
}
else
{
result = DISABLE;
}
break;
case TEMP_L_T_INT:
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, THERMAL_INT_REG) & BIT_2_MASK)
{
result = ENABLE;
}
else
{
result = DISABLE;
}
break;
case TEMP_R_T_INT:
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, THERMAL_INT_REG) & BIT_3_MASK)
{
result = ENABLE;
}
else
{
result = DISABLE;
}
break;
}
mutex_unlock(&data->update_lock);
sprintf(buf, "%s%d\n", buf, result);
return sprintf(buf, "%s\n", buf);
}
ssize_t themal_int_mask_get(struct device *dev, struct device_attribute *da, char *buf)
{
int result = 0;
struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
struct Cameo_i2c_data *data = i2c_get_clientdata(Cameo_CPLD_30_client);
mutex_lock(&data->update_lock);
sprintf(buf, "");
switch (attr->index)
{
case TEMP_R_B_INT_MASK:
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, THERMAL_INT_MASK_REG) & BIT_0_MASK)
{
result = ENABLE;
}
else
{
result = DISABLE;
}
break;
case TEMP_L_B_INT_MASK:
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, THERMAL_INT_MASK_REG) & BIT_1_MASK)
{
result = ENABLE;
}
else
{
result = DISABLE;
}
break;
case TEMP_L_T_INT_MASK:
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, THERMAL_INT_MASK_REG) & BIT_2_MASK)
{
result = ENABLE;
}
else
{
result = DISABLE;
}
break;
case TEMP_R_T_INT_MASK:
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, THERMAL_INT_MASK_REG) & BIT_3_MASK)
{
result = ENABLE;
}
else
{
result = DISABLE;
}
break;
}
mutex_unlock(&data->update_lock);
sprintf(buf, "%s%d\n", buf, result);
return sprintf(buf, "%s\n", buf);
}
ssize_t themal_int_mask_set(struct device *dev, struct device_attribute *da, const char *buf, size_t count)
{
int status = -EPERM;
int value = -EPERM;
int result = -EPERM;
int input;
struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
struct Cameo_i2c_data *data = i2c_get_clientdata(Cameo_CPLD_30_client);
mutex_lock(&data->update_lock);
status = i2c_smbus_read_byte_data(Cameo_CPLD_30_client, THERMAL_INT_MASK_REG);
input = simple_strtol(buf, NULL, 10);
switch (attr->index)
{
case TEMP_R_B_INT_MASK:
if (input == ENABLE)
{
value = status | 0x01;
}
else if (input == DISABLE)
{
value = status & 0xfe;
}
else
{
printk(KERN_ALERT "themal_int_mask_set wrong Value\n");
return count;
}
break;
case TEMP_L_B_INT_MASK:
if (input == ENABLE)
{
value = status | 0x02;
}
else if (input == DISABLE)
{
value = status & 0xfd;
}
else
{
printk(KERN_ALERT "themal_int_mask_set wrong Value\n");
return count;
}
break;
case TEMP_L_T_INT_MASK:
if (input == ENABLE)
{
value = status | 0x04;
}
else if (input == DISABLE)
{
value = status & 0xfb;
}
else
{
printk(KERN_ALERT "themal_int_mask_set wrong Value\n");
return count;
}
break;
case TEMP_R_T_INT_MASK:
if (input == ENABLE)
{
value = status | 0x08;
}
else if (input == DISABLE)
{
value = status & 0xf7;
}
else
{
printk(KERN_ALERT "themal_int_mask_set wrong Value\n");
return count;
}
break;
}
result = i2c_smbus_write_byte_data(Cameo_CPLD_30_client, THERMAL_INT_MASK_REG, value);
mutex_unlock(&data->update_lock);
return count;
}
ssize_t sys_int_get(struct device *dev, struct device_attribute *da, char *buf)
{
int result = 0;
struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
struct Cameo_i2c_data *data = i2c_get_clientdata(Cameo_CPLD_30_client);
mutex_lock(&data->update_lock);
sprintf(buf, "");
switch (attr->index)
{
case CPLD_FP_INT:
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, SYS_INT_REG) & BIT_2_MASK)
{
result = ENABLE;
}
else
{
result = DISABLE;
}
break;
case CPLD_RP_INT:
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, SYS_INT_REG) & BIT_3_MASK)
{
result = ENABLE;
}
else
{
result = DISABLE;
}
break;
case CPLD_FAN_INT:
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, SYS_INT_REG) & BIT_4_MASK)
{
result = ENABLE;
}
else
{
result = DISABLE;
}
break;
case CPLD_PSU_INT:
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, SYS_INT_REG) & BIT_5_MASK)
{
result = ENABLE;
}
else
{
result = DISABLE;
}
break;
case THERMAL_INT:
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, SYS_INT_REG) & BIT_6_MASK)
{
result = ENABLE;
}
else
{
result = DISABLE;
}
break;
case USB_INT:
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, SYS_INT_REG) & BIT_7_MASK)
{
result = ENABLE;
}
else
{
result = DISABLE;
}
break;
}
mutex_unlock(&data->update_lock);
sprintf(buf, "%s%d\n", buf, result);
return sprintf(buf, "%s\n", buf);
}
ssize_t sys_int_mask_get(struct device *dev, struct device_attribute *da, char *buf)
{
int result = 0;
struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
struct Cameo_i2c_data *data = i2c_get_clientdata(Cameo_CPLD_30_client);
mutex_lock(&data->update_lock);
sprintf(buf, "");
switch (attr->index)
{
case CPLD_FP_INT_MASK:
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, SYS_INT_MASK_REG) & BIT_2_MASK)
{
result = ENABLE;
}
else
{
result = DISABLE;
}
break;
case CPLD_RP_INT_MASK:
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, SYS_INT_MASK_REG) & BIT_3_MASK)
{
result = ENABLE;
}
else
{
result = DISABLE;
}
break;
case CPLD_FAN_INT_MASK:
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, SYS_INT_MASK_REG) & BIT_4_MASK)
{
result = ENABLE;
}
else
{
result = DISABLE;
}
break;
case CPLD_PSU_INT_MASK:
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, SYS_INT_MASK_REG) & BIT_5_MASK)
{
result = ENABLE;
}
else
{
result = DISABLE;
}
break;
case THERMAL_INT_MASK:
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, SYS_INT_MASK_REG) & BIT_6_MASK)
{
result = ENABLE;
}
else
{
result = DISABLE;
}
break;
case USB_INT_MASK:
if (i2c_smbus_read_byte_data(Cameo_CPLD_30_client, SYS_INT_MASK_REG) & BIT_7_MASK)
{
result = ENABLE;
}
else
{
result = DISABLE;
}
break;
}
mutex_unlock(&data->update_lock);
sprintf(buf, "%s%d\n", buf, result);
return sprintf(buf, "%s\n", buf);
}
ssize_t sys_int_mask_set(struct device *dev, struct device_attribute *da, const char *buf, size_t count)
{
int status = -EPERM;
int value = -EPERM;
int result = -EPERM;
int input;
struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
struct Cameo_i2c_data *data = i2c_get_clientdata(Cameo_CPLD_30_client);
mutex_lock(&data->update_lock);
status = i2c_smbus_read_byte_data(Cameo_CPLD_30_client, SYS_INT_MASK_REG);
input = simple_strtol(buf, NULL, 10);
switch (attr->index)
{
case CPLD_FP_INT_MASK:
if (input == ENABLE)
{
value = status | 0x02;
}
else if (input == DISABLE)
{
value = status & 0xfd;
}
else
{
printk(KERN_ALERT "sys_int_mask_set wrong Value\n");
return count;
}
break;
case CPLD_RP_INT_MASK:
if (input == ENABLE)
{
value = status | 0x04;
}
else if (input == DISABLE)
{
value = status & 0xfb;
}
else
{
printk(KERN_ALERT "sys_int_mask_set wrong Value\n");
return count;
}
break;
case CPLD_FAN_INT_MASK:
if (input == ENABLE)
{
value = status | 0x08;
}
else if (input == DISABLE)
{
value = status & 0xf7;
}
else
{
printk(KERN_ALERT "sys_int_mask_set wrong Value\n");
return count;
}
break;
case CPLD_PSU_INT_MASK:
if (input == ENABLE)
{
value = status | 0x10;
}
else if (input == DISABLE)
{
value = status & 0xef;
}
else
{
printk(KERN_ALERT "sys_int_mask_set wrong Value\n");
return count;
}
break;
case THERMAL_INT_MASK:
if (input == ENABLE)
{
value = status | 0x20;
}
else if (input == DISABLE)
{
value = status & 0xdf;
}
else
{
printk(KERN_ALERT "sys_int_mask_set wrong Value\n");
return count;
}
break;
case USB_INT_MASK:
if (input == ENABLE)
{
value = status | 0x40;
}
else if (input == DISABLE)
{
value = status & 0xbf;
}
else
{
printk(KERN_ALERT "sys_int_mask_set wrong Value\n");
return count;
}
break;
}
result = i2c_smbus_write_byte_data(Cameo_CPLD_30_client, SYS_INT_MASK_REG, value);
mutex_unlock(&data->update_lock);
return count;
}
/* end of implement i2c_function */