coreboot
coreboot is an Open Source project aimed at replacing the proprietary BIOS found in most computers.
nau8825.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 <stdint.h>
10 #include "chip.h"
11 
12 #if CONFIG(HAVE_ACPI_TABLES)
13 
14 #define NAU8825_ACPI_NAME "NAU8"
15 #define NAU8825_ACPI_HID "10508825"
16 
17 #define NAU8825_DP_INT(key,val) \
18  acpi_dp_add_integer(dp, "nuvoton," key, (val))
19 
20 static void nau8825_fill_ssdt(const struct device *dev)
21 {
23  const char *scope = acpi_device_scope(dev);
24  struct acpi_i2c i2c = {
25  .address = dev->path.i2c.device,
26  .mode_10bit = dev->path.i2c.mode_10bit,
27  .speed = config->bus_speed ? : I2C_SPEED_FAST,
28  .resource = scope,
29  };
30  struct acpi_dp *dp = NULL;
31 
32  if (!scope)
33  return;
34  if (config->sar_threshold_num > NAU8825_MAX_BUTTONS)
35  return;
36 
37  /* Device */
38  acpigen_write_scope(scope);
40  acpigen_write_name_string("_HID", NAU8825_ACPI_HID);
41  acpigen_write_name_integer("_UID", 0);
44 
45  /* Resources */
46  acpigen_write_name("_CRS");
49  /* Allow either GpioInt() or Interrupt() */
50  if (config->irq_gpio.pin_count)
51  acpi_device_write_gpio(&config->irq_gpio);
52  else
55 
56  /* Device Properties */
57  dp = acpi_dp_new_table("_DSD");
58  NAU8825_DP_INT("jkdet-enable", config->jkdet_enable);
59  NAU8825_DP_INT("jkdet-pull-enable", config->jkdet_pull_enable);
60  NAU8825_DP_INT("jkdet-pull-up", config->jkdet_pull_up);
61  NAU8825_DP_INT("jkdet-polarity", config->jkdet_polarity);
62  NAU8825_DP_INT("vref-impedance", config->vref_impedance);
63  NAU8825_DP_INT("micbias-voltage", config->micbias_voltage);
64  NAU8825_DP_INT("sar-hysteresis", config->sar_hysteresis);
65  NAU8825_DP_INT("sar-voltage", config->sar_voltage);
66  NAU8825_DP_INT("sar-compare-time", config->sar_compare_time);
67  NAU8825_DP_INT("sar-sampling-time", config->sar_sampling_time);
68  NAU8825_DP_INT("short-key-debounce", config->short_key_debounce);
69  NAU8825_DP_INT("jack-insert-debounce", config->jack_insert_debounce);
70  NAU8825_DP_INT("jack-eject-deboune", config->jack_eject_debounce);
71  NAU8825_DP_INT("sar-threshold-num", config->sar_threshold_num);
72  acpi_dp_add_integer_array(dp, "nuvoton,sar-threshold",
73  config->sar_threshold, config->sar_threshold_num);
74  acpi_dp_write(dp);
75 
76  acpigen_pop_len(); /* Device */
77  acpigen_pop_len(); /* Scope */
78 
79  printk(BIOS_INFO, "%s: %s address 0%xh irq %d\n",
80  acpi_device_path(dev), dev->chip_ops->name,
81  dev->path.i2c.device, config->irq.pin);
82 }
83 
84 static const char *nau8825_acpi_name(const struct device *dev)
85 {
86  return NAU8825_ACPI_NAME;
87 }
88 #endif
89 
90 static struct device_operations nau8825_ops = {
92  .set_resources = noop_set_resources,
93 #if CONFIG(HAVE_ACPI_TABLES)
94  .acpi_name = nau8825_acpi_name,
95  .acpi_fill_ssdt = nau8825_fill_ssdt,
96 #endif
97 };
98 
99 static void nau8825_enable(struct device *dev)
100 {
101  dev->ops = &nau8825_ops;
102 }
103 
105  CHIP_NAME("Nuvoton NAU8825 Codec")
106  .enable_dev = nau8825_enable
107 };
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
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
#define NAU8825_MAX_BUTTONS
Definition: chip.h:5
#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
static struct device_operations nau8825_ops
Definition: nau8825.c:90
struct chip_operations drivers_i2c_nau8825_ops
Definition: nau8825.c:104
static void nau8825_enable(struct device *dev)
Definition: nau8825.c:99
#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