coreboot
coreboot is an Open Source project aimed at replacing the proprietary BIOS found in most computers.
chip.c
Go to the documentation of this file.
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 
3 #include <acpi/acpi_device.h>
4 #include <acpi/acpigen.h>
5 #include <console/console.h>
6 #include <device/i2c_simple.h>
7 #include <device/device.h>
8 #include <device/path.h>
9 #include "tpm.h"
10 #include "chip.h"
11 
12 static void i2c_tpm_fill_ssdt(const struct device *dev)
13 {
14  struct acpi_dp *dsd;
16  const char *scope = acpi_device_scope(dev);
17  struct acpi_i2c i2c = {
18  .address = dev->path.i2c.device,
19  .mode_10bit = dev->path.i2c.mode_10bit,
20  .speed = config->speed ? : I2C_SPEED_FAST,
21  .resource = scope,
22  };
23 
24  if (!scope)
25  return;
26 
27  if (!config->hid) {
28  printk(BIOS_ERR, "%s: ERROR: HID required\n", dev_path(dev));
29  return;
30  }
31 
32  /* Device */
33  acpigen_write_scope(scope);
35  acpigen_write_name_string("_HID", config->hid);
36  acpigen_write_name_integer("_UID", config->uid);
39 
40  /* Resources */
41  acpigen_write_name("_CRS");
44  if (config->irq_gpio.pin_count)
45  acpi_device_write_gpio(&config->irq_gpio);
46  else
48 
50 
51  /* _DSD, Device-Specific Data */
52  dsd = acpi_dp_new_table("_DSD");
53  switch (config->power_managed_mode) {
55  acpi_dp_add_integer(dsd, "firmware-power-managed", 1);
56  break;
58  acpi_dp_add_integer(dsd, "firmware-power-managed", 0);
59  break;
61  default:
62  /* Leave firmware-power-managed unset */
63  break;
64  }
65  acpi_dp_write(dsd);
66 
67  acpigen_pop_len(); /* Device */
68  acpigen_pop_len(); /* Scope */
69 
70  printk(BIOS_INFO, "%s: %s at %s\n", acpi_device_path(dev),
71  dev->chip_ops->name, dev_path(dev));
72 }
73 
74 static const char *i2c_tpm_acpi_name(const struct device *dev)
75 {
76  return "TPMI";
77 }
78 
79 static struct device_operations i2c_tpm_ops = {
81  .set_resources = noop_set_resources,
82  .acpi_name = i2c_tpm_acpi_name,
83  .acpi_fill_ssdt = i2c_tpm_fill_ssdt,
84 };
85 
86 static void i2c_tpm_enable(struct device *dev)
87 {
89 
90  dev->ops = &i2c_tpm_ops;
91 
92  if (config && config->desc) {
93  dev->name = config->desc;
94  }
95 }
96 
98  CHIP_NAME("I2C TPM")
99  .enable_dev = i2c_tpm_enable
100 };
void acpi_device_write_gpio(const struct acpi_gpio *gpio)
Definition: device.c:258
const char * acpi_device_path(const struct device *dev)
Definition: device.c:144
void acpi_device_write_interrupt(const struct acpi_irq *irq)
Definition: device.c:209
struct acpi_dp * acpi_dp_add_integer(struct acpi_dp *dp, const char *name, uint64_t value)
Definition: device.c:977
void acpi_device_write_i2c(const struct acpi_i2c *i2c)
Definition: device.c:399
void acpi_dp_write(struct acpi_dp *table)
Definition: device.c:898
int acpi_device_status(const struct device *dev)
Definition: device.c:193
const char * acpi_device_name(const struct device *dev)
Definition: device.c:49
struct acpi_dp * acpi_dp_new_table(const char *name)
Definition: device.c:930
const char * acpi_device_scope(const struct device *dev)
Definition: device.c:158
void acpigen_pop_len(void)
Definition: acpigen.c:37
void acpigen_write_scope(const char *name)
Definition: acpigen.c:326
void acpigen_write_resourcetemplate_footer(void)
Definition: acpigen.c:1165
void acpigen_write_name_integer(const char *name, uint64_t val)
Definition: acpigen.c:170
void acpigen_write_STA(uint8_t status)
Definition: acpigen.c:783
void acpigen_write_resourcetemplate_header(void)
Definition: acpigen.c:1147
void acpigen_write_device(const char *name)
Definition: acpigen.c:769
void acpigen_write_name(const char *name)
Definition: acpigen.c:320
void acpigen_write_name_string(const char *name, const char *string)
Definition: acpigen.c:176
#define printk(level,...)
Definition: stdlib.h:16
const char * dev_path(const struct device *dev)
Definition: device_util.c:149
struct chip_operations drivers_i2c_tpm_ops
Definition: chip.c:97
static const char * i2c_tpm_acpi_name(const struct device *dev)
Definition: chip.c:74
static void i2c_tpm_fill_ssdt(const struct device *dev)
Definition: chip.c:12
static struct device_operations i2c_tpm_ops
Definition: chip.c:79
static void i2c_tpm_enable(struct device *dev)
Definition: chip.c:86
@ TPM_FIRMWARE_POWER_MANAGED
Definition: chip.h:8
@ TPM_KERNEL_POWER_MANAGED
Definition: chip.h:9
@ TPM_DEFAULT_POWER_MANAGED
Definition: chip.h:7
#define CHIP_NAME(X)
Definition: device.h:32
static void noop_read_resources(struct device *dev)
Standard device operations function pointers shims.
Definition: device.h:73
static void noop_set_resources(struct device *dev)
Definition: device.h:74
@ I2C_SPEED_FAST
Definition: i2c.h:45
#define BIOS_INFO
BIOS_INFO - Expected events.
Definition: loglevel.h:113
#define BIOS_ERR
BIOS_ERR - System in incomplete state.
Definition: loglevel.h:72
enum board_config config
Definition: memory.c:448
uint16_t address
Definition: acpi_device.h:304
const char * name
Definition: device.h:29
void(* read_resources)(struct device *dev)
Definition: device.h:39
struct i2c_path i2c
Definition: path.h:118
Definition: device.h:107
struct chip_operations * chip_ops
Definition: device.h:144
const char * name
Definition: device.h:145
struct device_path path
Definition: device.h:115
struct device_operations * ops
Definition: device.h:143
DEVTREE_CONST void * chip_info
Definition: device.h:164
unsigned int device
Definition: path.h:63
unsigned int mode_10bit
Definition: path.h:64