coreboot
coreboot is an Open Source project aimed at replacing the proprietary BIOS found in most computers.
cs42l42.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 
10 #include "chip.h"
11 
12 #define CS42L42_ACPI_NAME "CRUS"
13 #define CS42L42_ACPI_HID "10134242"
14 
15 static void cs42l42_fill_ssdt(const struct device *dev)
16 {
18  const char *scope = acpi_device_scope(dev);
19  const char *path = acpi_device_path(dev);
20  struct acpi_i2c i2c = {
21  .address = dev->path.i2c.device,
22  .mode_10bit = dev->path.i2c.mode_10bit,
23  .speed = config->bus_speed ? : I2C_SPEED_FAST,
24  .resource = scope,
25  };
26  struct acpi_dp *dsd;
27  int gpio_index = 0;
28 
29  if (!scope)
30  return;
31 
32  /* Device */
33  acpigen_write_scope(scope);
36  acpigen_write_name_integer("_UID", 0);
39 
40  /* Resources */
41  acpigen_write_name("_CRS");
44  /* Use either Interrupt() or GpioInt() */
45  if (config->irq_gpio.pin_count)
46  acpi_device_write_gpio(&config->irq_gpio);
47  else
49 
50  /* for cs42l42reset gpio */
51  if (config->reset_gpio.pin_count)
52  acpi_device_write_gpio(&config->reset_gpio);
53 
55 
56  /* AAD Child Device Properties */
57  dsd = acpi_dp_new_table("_DSD");
58  if (config->irq_gpio.pin_count)
59  acpi_dp_add_gpio(dsd, "irq-gpios", path,
60  gpio_index++, /* Index = 0 */
61  0, /* Pin = 0 (There is a single pin in the GPIO resource). */
62  config->irq_gpio.active_low);
63  if (config->reset_gpio.pin_count)
64  acpi_dp_add_gpio(dsd, "reset-gpios", path,
65  gpio_index++, /* Index = 0 or 1 (if irq gpio is written). */
66  0, /* Pin = 0 (There is a single pin in the GPIO resource). */
67  config->reset_gpio.active_low);
68  acpi_dp_add_integer(dsd, "cirrus,ts-inv", config->ts_inv ? 1 : 0);
69  acpi_dp_add_integer(dsd, "cirrus,ts-dbnc-rise", config->ts_dbnc_rise);
70  acpi_dp_add_integer(dsd, "cirrus,ts-dbnc-fall", config->ts_dbnc_fall);
71  acpi_dp_add_integer(dsd, "cirrus,btn-det-init-dbnce", config->btn_det_init_dbnce);
72 
73  if (config->btn_det_init_dbnce > 200) {
74  printk(BIOS_ERR, "%s: Incorrect btn_det_init_dbnce(%d). Using default of 100ms\n",
75  __func__, config->btn_det_init_dbnce);
76  config->btn_det_init_dbnce = 100;
77  }
78 
79  acpi_dp_add_integer(dsd, "cirrus,btn-det-event-dbnce", config->btn_det_event_dbnce);
80 
81  if (config->btn_det_event_dbnce > 100) {
82  printk(BIOS_ERR, "%s: Incorrect btn_det_event_dbnce(%d). Using default of 10ms\n",
83  __func__, config->btn_det_event_dbnce);
84  config->btn_det_event_dbnce = 10;
85  }
86 
87  acpi_dp_add_integer_array(dsd, "cirrus,bias-lvls", config->bias_lvls, 4);
88  acpi_dp_add_integer(dsd, "cirrus,hs-bias-ramp-rate", config->hs_bias_ramp_rate);
89  if (config->hs_bias_sense_disable)
90  acpi_dp_add_integer(dsd, "cirrus,hs-bias-sense-disable", 1);
91 
92  /* Write Device Property Hierarchy */
93  acpi_dp_write(dsd);
94 
95  acpigen_pop_len(); /* Device */
96  acpigen_pop_len(); /* Scope */
97 
98  printk(BIOS_INFO, "%s: %s address 0%xh irq %d\n",
99  acpi_device_path(dev), dev->chip_ops->name,
100  dev->path.i2c.device, config->irq.pin);
101 }
102 
103 static const char *cs42l42_acpi_name(const struct device *dev)
104 {
105  return CS42L42_ACPI_NAME;
106 }
107 
108 static struct device_operations cs42l42_ops = {
110  .set_resources = noop_set_resources,
111  .acpi_name = cs42l42_acpi_name,
112  .acpi_fill_ssdt = cs42l42_fill_ssdt,
113 };
114 
115 static void cs42l42_enable(struct device *dev)
116 {
117  dev->ops = &cs42l42_ops;
118 }
119 
121  CHIP_NAME("Cirrus Logic CS42l42 Audio Codec")
122  .enable_dev = cs42l42_enable
123 };
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
struct acpi_dp * acpi_dp_add_integer_array(struct acpi_dp *dp, const char *name, const uint64_t *array, int len)
Definition: device.c:1066
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
struct acpi_dp * acpi_dp_add_gpio(struct acpi_dp *dp, const char *name, const char *ref, int index, int pin, int active_low)
Definition: device.c:1142
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
#define CS42L42_ACPI_HID
Definition: cs42l42.c:13
static void cs42l42_fill_ssdt(const struct device *dev)
Definition: cs42l42.c:15
struct chip_operations drivers_i2c_cs42l42_ops
Definition: cs42l42.c:120
static const char * cs42l42_acpi_name(const struct device *dev)
Definition: cs42l42.c:103
static void cs42l42_enable(struct device *dev)
Definition: cs42l42.c:115
#define CS42L42_ACPI_NAME
Definition: cs42l42.c:12
static struct device_operations cs42l42_ops
Definition: cs42l42.c:108
#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
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