| /* Copyright 2021 The ChromiumOS Authors |
| * Use of this source code is governed by a BSD-style license that can be |
| * found in the LICENSE file. |
| */ |
| |
| #ifndef _RAMMUS_CBI_SSFC__H_ |
| #define _RAMMUS_CBI_SSFC__H_ |
| |
| #include "stdint.h" |
| |
| /**************************************************************************** |
| * Rammus CBI Second Source Factory Cache |
| */ |
| |
| /* |
| * Lid Sensor (Bits 2-0) |
| */ |
| enum ec_ssfc_lid_sensor { |
| SSFC_SENSOR_LID_DEFAULT = 0, |
| SSFC_SENSOR_LID_BMA255 = 1, |
| SSFC_SENSOR_LID_KX022 = 2 |
| }; |
| |
| /* |
| * Base Sensor (Bits 5-3) |
| */ |
| enum ec_ssfc_base_sensor { |
| SSFC_SENSOR_BASE_DEFAULT = 0, |
| SSFC_SENSOR_BASE_BMI160 = 1, |
| SSFC_SENSOR_BASE_ICM426XX = 2, |
| }; |
| |
| union rammus_cbi_ssfc { |
| struct { |
| enum ec_ssfc_lid_sensor lid_sensor : 3; |
| enum ec_ssfc_base_sensor base_sensor : 3; |
| uint32_t reserved_2 : 26; |
| }; |
| uint32_t raw_value; |
| }; |
| |
| /** |
| * Get the Lid sensor type from SSFC_CONFIG. |
| * |
| * @return the Lid sensor board type. |
| */ |
| enum ec_ssfc_lid_sensor get_cbi_ssfc_lid_sensor(void); |
| |
| /** |
| * Get the base sensor type form SSFC_CONFIG. |
| * |
| * @return the base sensor board type. |
| */ |
| enum ec_ssfc_base_sensor get_cbi_ssfc_base_sensor(void); |
| |
| #endif /* _RAMMUS_CBI_SSFC__H_ */ |