blob: 35570b0b72bfea48ed7a6430a0c3c5b5f95bd0be (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
|
/*
* This file is part of the coreboot project.
*
* Copyright (C) 2017 Patrick Rudolph <siro@das-labor.org>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; version 2 of the License.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*/
#include <console/console.h>
#include <arch/acpigen.h>
#include <string.h>
#include "h8.h"
#include "chip.h"
static char *h8_dsdt_scope(struct device *dev, const char *scope)
{
static char buf[DEVICE_PATH_MAX] = {};
const char *path = acpi_device_path(dev);
memset(buf, 0, sizeof(buf));
snprintf(buf, sizeof(buf) - 1, "%s.%s", path, scope);
return buf;
}
/*
* Generates EC SSDT.
*/
void h8_ssdt_generator(struct device *dev)
{
if (!acpi_device_path(dev))
return;
printk(BIOS_INFO, "ACPI: * H8\n");
/* Scope HKEY */
acpigen_write_scope(h8_dsdt_scope(dev, "HKEY"));
/* Used by thinkpad_acpi */
acpigen_write_name_byte("HBDC", h8_has_bdc(dev) ? ONE_OP : ZERO_OP);
acpigen_pop_len(); /* Scope HKEY */
}
|