summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJonathan Zhang <jonzhang@meta.com>2022-10-14 17:06:26 -0700
committerMartin Roth <martin.roth@amd.corp-partner.google.com>2022-11-17 21:17:49 +0000
commitd57b82111a87767184405cffc1bad3ef58925a6c (patch)
tree6ff54776c87861bee613d2af736238e8e71dac0b /src
parent0f5b87cf95992ffddb9bc9bd08ee4d6af046bd92 (diff)
arch/x86/smbios: Add SMBIOS Type 39
Read FRU product info of PSU to get Type 39 required information. Further development needed if multi-record info of PSU FRU is required. For now, the read_fru_areas() only read product chassis and board info. Signed-off-by: lichenchen.carl <lichenchen.carl@bytedance.com> Signed-off-by: ziang <ziang.wang@intel.com> Signed-off-by: Jonathan Zhang <jonzhang@meta.com> Change-Id: I18d056cba1a79b0775c8a42b3a879e819887adca Reviewed-on: https://review.coreboot.org/c/coreboot/+/68443 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Shuming Chu (Shuming) <s1218944@gmail.com> Reviewed-by: Angel Pons <th3fanbus@gmail.com> Reviewed-by: Arthur Heymans <arthur@aheymans.xyz> Reviewed-by: Christian Walter <christian.walter@9elements.com>
Diffstat (limited to 'src')
-rw-r--r--src/arch/x86/smbios.c49
-rw-r--r--src/include/smbios.h64
2 files changed, 113 insertions, 0 deletions
diff --git a/src/arch/x86/smbios.c b/src/arch/x86/smbios.c
index 24b18f2988..5b8df5bc64 100644
--- a/src/arch/x86/smbios.c
+++ b/src/arch/x86/smbios.c
@@ -1116,6 +1116,55 @@ int smbios_write_type38(unsigned long *current, int *handle,
return len;
}
+int smbios_write_type39(unsigned long *current, int *handle,
+ u8 unit_group, const char *loc, const char *dev_name,
+ const char *man, const char *serial_num,
+ const char *tag_num, const char *part_num,
+ const char *rev_lvl, u16 max_pow_cap,
+ const struct power_supply_ch *ps_ch)
+{
+ struct smbios_type39 *t = smbios_carve_table(*current,
+ SMBIOS_SYSTEM_POWER_SUPPLY,
+ sizeof(*t), *handle);
+
+ uint16_t val = 0;
+ uint16_t ps_type, ps_status, vol_switch, ps_unplug, ps_present, hot_rep;
+
+ t->power_unit_group = unit_group;
+ t->location = smbios_add_string(t->eos, loc);
+ t->device_name = smbios_add_string(t->eos, dev_name);
+ t->manufacturer = smbios_add_string(t->eos, man);
+ t->serial_number = smbios_add_string(t->eos, serial_num);
+ t->asset_tag_number = smbios_add_string(t->eos, tag_num);
+ t->model_part_number = smbios_add_string(t->eos, part_num);
+ t->revision_level = smbios_add_string(t->eos, rev_lvl);
+ t->max_power_capacity = max_pow_cap;
+
+ ps_type = ps_ch->power_supply_type & 0xF;
+ ps_status = ps_ch->power_supply_status & 0x7;
+ vol_switch = ps_ch->input_voltage_range_switch & 0xF;
+ ps_unplug = ps_ch->power_supply_unplugged & 0x1;
+ ps_present = ps_ch->power_supply_present & 0x1;
+ hot_rep = ps_ch->power_supply_hot_replaceble & 0x1;
+
+ val |= (ps_type << 10);
+ val |= (ps_status << 7);
+ val |= (vol_switch << 3);
+ val |= (ps_unplug << 2);
+ val |= (ps_present << 1);
+ val |= hot_rep;
+ t->power_supply_characteristics = val;
+
+ t->input_voltage_probe_handle = 0xFFFF;
+ t->cooling_device_handle = 0xFFFF;
+ t->input_current_probe_handle = 0xFFFF;
+
+ const int len = smbios_full_table_len(&t->header, t->eos);
+ *current += len;
+ *handle += 1;
+ return len;
+}
+
int smbios_write_type41(unsigned long *current, int *handle,
const char *name, u8 instance, u16 segment,
u8 bus, u8 device, u8 function, u8 device_type)
diff --git a/src/include/smbios.h b/src/include/smbios.h
index cb317b03a3..9217f5eaa0 100644
--- a/src/include/smbios.h
+++ b/src/include/smbios.h
@@ -270,6 +270,7 @@ typedef enum {
SMBIOS_TEMPERATURE_PROBE = 28,
SMBIOS_SYSTEM_BOOT_INFORMATION = 32,
SMBIOS_IPMI_DEVICE_INFORMATION = 38,
+ SMBIOS_SYSTEM_POWER_SUPPLY = 39,
SMBIOS_ONBOARD_DEVICES_EXTENDED_INFORMATION = 41,
SMBIOS_TPM_DEVICE = 43,
SMBIOS_END_OF_TABLE = 127,
@@ -1013,6 +1014,69 @@ enum smbios_bmc_interface_type {
};
typedef enum {
+ PowerSupplyTypeOther = 1,
+ PowerSupplyTypeUnknown = 2,
+ PowerSupplyTypeLinear = 3,
+ PowerSupplyTypeSwitching = 4,
+ PowerSupplyTypeBattery = 5,
+ PowerSupplyTypeUps = 6,
+ PowerSupplyTypeConverter = 7,
+ PowerSupplyTypeRegulator = 8
+} power_supply_type;
+
+typedef enum {
+ PowerSupplyStatusOther = 1,
+ PowerSupplyStatusUnknown = 2,
+ PowerSupplyStatusOk = 3,
+ PowerSupplyStatusNonCritical = 4,
+ PowerSupplyStatusCritical = 5
+} power_supply_status;
+
+typedef enum {
+ PowerSupplyInputVoltageRangeSwitchingOther = 1,
+ PowerSupplyInputVoltageRangeSwitchingUnknown = 2,
+ PowerSupplyInputVoltageRangeSwitchingManual = 3,
+ PowerSupplyInputVoltageRangeSwitchingAutoSwitch = 4,
+ PowerSupplyInputVoltageRangeSwitchingWideRange = 5,
+ PowerSupplyInputVoltageRangeSwitchingNotApplicable = 6
+} power_supply_input_voltage_range_switching;
+
+struct power_supply_ch {
+ u16 reserved :2;
+ u16 power_supply_type :4;
+ u16 power_supply_status :3;
+ u16 input_voltage_range_switch :4;
+ u16 power_supply_unplugged :1;
+ u16 power_supply_present :1;
+ u16 power_supply_hot_replaceble :1;
+};
+
+struct smbios_type39 {
+ struct smbios_header header;
+ u8 power_unit_group;
+ u8 location;
+ u8 device_name;
+ u8 manufacturer;
+ u8 serial_number;
+ u8 asset_tag_number;
+ u8 model_part_number;
+ u8 revision_level;
+ u16 max_power_capacity;
+ u16 power_supply_characteristics;
+ u16 input_voltage_probe_handle;
+ u16 cooling_device_handle;
+ u16 input_current_probe_handle;
+ u8 eos[2];
+} __packed;
+
+int smbios_write_type39(unsigned long *current, int *handle,
+ u8 unit_group, const char *loc, const char *dev_name,
+ const char *man, const char *serial_num,
+ const char *tag_num, const char *part_num,
+ const char *rev_lvl, u16 max_pow_cap,
+ const struct power_supply_ch *ps_ch);
+
+typedef enum {
SMBIOS_DEVICE_TYPE_OTHER = 0x01,
SMBIOS_DEVICE_TYPE_UNKNOWN,
SMBIOS_DEVICE_TYPE_VIDEO,