coreboot
coreboot is an Open Source project aimed at replacing the proprietary BIOS found in most computers.
da7219.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 #if CONFIG(HAVE_ACPI_TABLES)
14 
15 #define DA7219_ACPI_NAME "DLG7"
16 #define DA7219_ACPI_HID "DLGS7219"
17 
18 static void da7219_fill_ssdt(const struct device *dev)
19 {
21  const char *scope = acpi_device_scope(dev);
22  struct acpi_i2c i2c = {
23  .address = dev->path.i2c.device,
24  .mode_10bit = dev->path.i2c.mode_10bit,
25  .speed = config->bus_speed ? : I2C_SPEED_FAST,
26  .resource = scope,
27  };
28  struct acpi_dp *dsd, *aad;
29 
30  if (!scope)
31  return;
32 
33  /* Device */
34  acpigen_write_scope(scope);
36  acpigen_write_name_string("_HID", DA7219_ACPI_HID);
37  acpigen_write_name_integer("_UID", 1);
41 
42  /* Resources */
43  acpigen_write_name("_CRS");
46  /* Use either Interrupt() or GpioInt() */
47  if (config->irq_gpio.pin_count)
48  acpi_device_write_gpio(&config->irq_gpio);
49  else
52 
53  /* AAD Child Device Properties */
54  aad = acpi_dp_new_table("DAAD");
55  acpi_dp_add_integer(aad, "dlg,btn-cfg", config->btn_cfg);
56  acpi_dp_add_integer(aad, "dlg,mic-det-thr", config->mic_det_thr);
57  acpi_dp_add_integer(aad, "dlg,jack-ins-deb", config->jack_ins_deb);
58  acpi_dp_add_string(aad, "dlg,jack-det-rate", config->jack_det_rate);
59  acpi_dp_add_integer(aad, "dlg,jack-rem-deb", config->jack_rem_deb);
60  acpi_dp_add_integer(aad, "dlg,a-d-btn-thr", config->a_d_btn_thr);
61  acpi_dp_add_integer(aad, "dlg,d-b-btn-thr", config->d_b_btn_thr);
62  acpi_dp_add_integer(aad, "dlg,b-c-btn-thr", config->b_c_btn_thr);
63  acpi_dp_add_integer(aad, "dlg,c-mic-btn-thr", config->c_mic_btn_thr);
64  acpi_dp_add_integer(aad, "dlg,btn-avg", config->btn_avg);
65  acpi_dp_add_integer(aad, "dlg,adc-1bit-rpt", config->adc_1bit_rpt);
66  if (config->micbias_pulse_lvl > 0) {
67  acpi_dp_add_integer(aad, "dlg,micbias-pulse-lvl",
68  config->micbias_pulse_lvl);
69  acpi_dp_add_integer(aad, "dlg,micbias-pulse-time",
70  config->micbias_pulse_time);
71  }
72 
73  /* DA7219 Properties */
74  dsd = acpi_dp_new_table("_DSD");
75  acpi_dp_add_integer(dsd, "dlg,micbias-lvl", config->micbias_lvl);
76  acpi_dp_add_string(dsd, "dlg,mic-amp-in-sel", config->mic_amp_in_sel);
77  if (config->mclk_name != NULL)
78  acpi_dp_add_string(dsd, "dlg,mclk-name", config->mclk_name);
79  acpi_dp_add_child(dsd, "da7219_aad", aad);
80 
81  /* Write Device Property Hierarchy */
82  acpi_dp_write(dsd);
83 
84  acpigen_pop_len(); /* Device */
85  acpigen_pop_len(); /* Scope */
86 
87  printk(BIOS_INFO, "%s: %s address 0%xh irq %d\n",
88  acpi_device_path(dev), dev->chip_ops->name,
89  dev->path.i2c.device, config->irq.pin);
90 }
91 
92 static const char *da7219_acpi_name(const struct device *dev)
93 {
94  return DA7219_ACPI_NAME;
95 }
96 #endif
97 
98 static struct device_operations da7219_ops = {
100  .set_resources = noop_set_resources,
101 #if CONFIG(HAVE_ACPI_TABLES)
102  .acpi_name = da7219_acpi_name,
103  .acpi_fill_ssdt = da7219_fill_ssdt,
104 #endif
105 };
106 
107 static void da7219_enable(struct device *dev)
108 {
109  dev->ops = &da7219_ops;
110 }
111 
113  CHIP_NAME("Dialog Semiconductor DA7219 Audio Codec")
114  .enable_dev = da7219_enable
115 };
struct acpi_dp * acpi_dp_add_child(struct acpi_dp *dp, const char *name, struct acpi_dp *child)
Definition: device.c:1019
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_string(struct acpi_dp *dp, const char *name, const char *string)
Definition: device.c:991
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
struct chip_operations drivers_i2c_da7219_ops
Definition: da7219.c:112
static struct device_operations da7219_ops
Definition: da7219.c:98
static void da7219_enable(struct device *dev)
Definition: da7219.c:107
@ ACPI_DEVICE_SLEEP_D3_HOT
Definition: acpi.h:52
#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
enum board_config config
Definition: memory.c:448
#define NULL
Definition: stddef.h:19
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