coreboot
coreboot is an Open Source project aimed at replacing the proprietary BIOS found in most computers.
cs35l53.c
Go to the documentation of this file.
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 
3 #include <acpi/acpi.h>
4 #include <acpi/acpi_device.h>
5 #include <acpi/acpigen.h>
6 #include <console/console.h>
7 #include <device/i2c_simple.h>
8 #include <device/device.h>
9 #include <device/path.h>
10 
11 #include "chip.h"
12 
13 #define CS35L53_ACPI_HID "CSC3541"
14 
15 static void cs35l53_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);
38  acpigen_write_name_string("_SUB", config->sub);
40 
41  /* Resources */
42  acpigen_write_name("_CRS");
45  /* Use either Interrupt() or GpioInt() */
46  if (config->irq_gpio.pin_count)
47  acpi_device_write_gpio(&config->irq_gpio);
48  else
50 
51  /* for cs35l53 reset gpio */
52  if (config->reset_gpio.pin_count)
53  acpi_device_write_gpio(&config->reset_gpio);
54 
56 
57  /* Add Child Device Properties */
58  dsd = acpi_dp_new_table("_DSD");
59  if (config->irq_gpio.pin_count)
60  acpi_dp_add_gpio(dsd, "irq-gpios", path,
61  gpio_index++, /* Index = 0 */
62  0, /* Pin = 0 (There is a single pin in the GPIO resource). */
63  config->irq_gpio.active_low);
64  if (config->reset_gpio.pin_count)
65  acpi_dp_add_gpio(dsd, "reset-gpios", path,
66  gpio_index++, /* Index = 0 or 1 (if irq gpio is written). */
67  0, /* Pin = 0 (There is a single pin in the GPIO resource). */
68  config->reset_gpio.active_low);
69 
70  acpi_dp_add_integer(dsd, "cirrus,boost-type", config->boost_type);
71 
72  switch (config->boost_type) {
73  case INTERNAL_BOOST:
74  if ((config->boost_peak_milliamp > 4500) ||
75  (config->boost_peak_milliamp < 1600) ||
76  (config->boost_peak_milliamp % 50)) {
78  "%s: Incorrect boost_peak_milliamp(%d). Using default of 4500 mA\n",
79  __func__, config->boost_peak_milliamp);
80  config->boost_peak_milliamp = 4500;
81  }
82  acpi_dp_add_integer(dsd, "cirrus,boost-peak-milliamp",
83  config->boost_peak_milliamp);
84  acpi_dp_add_integer(dsd, "cirrus,boost-ind-nanohenry",
85  config->boost_ind_nanohenry);
86  acpi_dp_add_integer(dsd, "cirrus,boost-cap-microfarad",
87  config->boost_cap_microfarad);
88  break;
89  case EXTERNAL_BOOST:
90  config->gpio1_output_enable = true;
91  config->gpio1_src_select = GPIO1_SRC_GPIO;
92  break;
93  default:
94  break;
95  }
96 
97  acpi_dp_add_integer(dsd, "cirrus,asp-sdout-hiz", config->asp_sdout_hiz);
98  acpi_dp_add_integer(dsd, "cirrus,gpio1-polarity-invert",
99  config->gpio1_polarity_invert);
100  acpi_dp_add_integer(dsd, "cirrus,gpio1-output-enable",
101  config->gpio1_output_enable);
102  acpi_dp_add_integer(dsd, "cirrus,gpio1-src-select", config->gpio1_src_select);
103  acpi_dp_add_integer(dsd, "cirrus,gpio2-polarity-invert",
104  config->gpio2_polarity_invert);
105  acpi_dp_add_integer(dsd, "cirrus,gpio2-output-enable",
106  config->gpio2_output_enable);
107  acpi_dp_add_integer(dsd, "cirrus,gpio2-src-select", config->gpio2_src_select);
108 
109  /* Write Device Property Hierarchy */
110  acpi_dp_write(dsd);
111 
112  acpigen_pop_len(); /* Device */
113  acpigen_pop_len(); /* Scope */
114 
115  printk(BIOS_INFO, "%s: %s address 0%xh irq %d\n",
116  acpi_device_path(dev), dev->chip_ops->name,
117  dev->path.i2c.device, config->irq.pin);
118 }
119 
120 static const char *cs35l53_acpi_name(const struct device *dev)
121 {
123  static char name[ACPI_NAME_BUFFER_SIZE];
124 
125  if (config->name)
126  return config->name;
127 
128  snprintf(name, sizeof(name), "D%03.3X", dev->path.i2c.device);
129  return name;
130 }
131 
132 static struct device_operations cs35l53_ops = {
134  .set_resources = noop_set_resources,
135  .acpi_name = cs35l53_acpi_name,
136  .acpi_fill_ssdt = cs35l53_fill_ssdt,
137 };
138 
139 static void cs35l53_enable(struct device *dev)
140 {
141  dev->ops = &cs35l53_ops;
142 }
143 
145  CHIP_NAME("Cirrus Logic CS35L53 Audio Codec")
146  .enable_dev = cs35l53_enable
147 };
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
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
const char * name
Definition: mmu.c:92
#define printk(level,...)
Definition: stdlib.h:16
static const char * cs35l53_acpi_name(const struct device *dev)
Definition: cs35l53.c:120
#define CS35L53_ACPI_HID
Definition: cs35l53.c:13
static void cs35l53_fill_ssdt(const struct device *dev)
Definition: cs35l53.c:15
static void cs35l53_enable(struct device *dev)
Definition: cs35l53.c:139
struct chip_operations drivers_i2c_cs35l53_ops
Definition: cs35l53.c:144
static struct device_operations cs35l53_ops
Definition: cs35l53.c:132
@ GPIO1_SRC_GPIO
Definition: chip.h:28
@ EXTERNAL_BOOST
Definition: chip.h:9
@ INTERNAL_BOOST
Definition: chip.h:8
#define ACPI_NAME_BUFFER_SIZE
Definition: acpi.h:59
#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
int snprintf(char *buf, size_t size, const char *fmt,...)
Note: This file is only for POSIX compatibility, and is meant to be chain-included via string....
Definition: vsprintf.c:35