coreboot
coreboot is an Open Source project aimed at replacing the proprietary BIOS found in most computers.
pmh7.c
Go to the documentation of this file.
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 
3 #include <arch/io.h>
4 #include <console/console.h>
5 #include <device/device.h>
6 #include <device/pnp.h>
7 #include <option.h>
8 #include <delay.h>
9 #include <types.h>
10 
11 #include "pmh7.h"
12 #include "chip.h"
13 
14 void pmh7_backlight_enable(int onoff)
15 {
16  if (onoff)
17  pmh7_register_set_bit(0x50, 5);
18  else
19  pmh7_register_clear_bit(0x50, 5);
20 }
21 
22 void pmh7_dock_event_enable(int onoff)
23 {
24  if (onoff)
25  pmh7_register_set_bit(0x60, 3);
26  else
27  pmh7_register_clear_bit(0x60, 3);
28 }
29 
30 void pmh7_touchpad_enable(int onoff)
31 {
32  if (onoff)
33  pmh7_register_clear_bit(0x51, 2);
34  else
35  pmh7_register_set_bit(0x51, 2);
36 }
37 
38 void pmh7_trackpoint_enable(int onoff)
39 {
40  if (onoff)
41  pmh7_register_clear_bit(0x51, 0);
42  else
43  pmh7_register_set_bit(0x51, 0);
44 }
45 
47 {
48  if (onoff)
49  pmh7_register_clear_bit(0x62, 0);
50  else
51  pmh7_register_set_bit(0x62, 0);
52 }
53 
54 void pmh7_dgpu_power_enable(int onoff)
55 {
56  if (onoff) {
57  pmh7_register_clear_bit(0x50, 7); // DGPU_RST
58  pmh7_register_set_bit(0x50, 3); // DGPU_PWR
59  mdelay(10);
60  pmh7_register_set_bit(0x50, 7); // DGPU_RST
61  mdelay(50);
62  } else {
63  pmh7_register_clear_bit(0x50, 7); // DGPU_RST
64  udelay(100);
65  pmh7_register_clear_bit(0x50, 3); // DGPU_PWR
66  }
67 }
68 
70 {
71  return (pmh7_register_read(0x50) & 0x08) == 8;
72 }
73 
74 void pmh7_register_set_bit(int reg, int bit)
75 {
76  char val;
77 
78  val = pmh7_register_read(reg);
79  pmh7_register_write(reg, val | (1 << bit));
80 }
81 
82 void pmh7_register_clear_bit(int reg, int bit)
83 {
84  char val;
85 
86  val = pmh7_register_read(reg);
87  pmh7_register_write(reg, val & ~(1 << bit));
88 }
89 
90 char pmh7_register_read(int reg)
91 {
92  outb(reg & 0xff, EC_LENOVO_PMH7_ADDR_L);
93  outb((reg & 0xff00) >> 8, EC_LENOVO_PMH7_ADDR_H);
94  return inb(EC_LENOVO_PMH7_DATA);
95 }
96 
97 void pmh7_register_write(int reg, int val)
98 {
99  outb(reg & 0xff, EC_LENOVO_PMH7_ADDR_L);
100  outb((reg & 0xff00) >> 8, EC_LENOVO_PMH7_ADDR_H);
102 }
103 
104 static void enable_dev(struct device *dev)
105 {
106  const struct ec_lenovo_pmh7_config *conf = dev->chip_info;
107  struct resource *resource;
108 
112  resource->size = 16;
113  resource->align = 5;
114  resource->gran = 5;
115 
118 
119  pmh7_touchpad_enable(get_uint_option("touchpad", 1));
120 
121  pmh7_trackpoint_enable(get_uint_option("trackpoint", 1));
122 
123  printk(BIOS_INFO, "PMH7: ID %02x Revision %02x\n",
126 }
127 
129  CHIP_NAME("Lenovo Power Management Hardware Hub 7")
130  .enable_dev = enable_dev,
131 };
#define printk(level,...)
Definition: stdlib.h:16
void mdelay(unsigned int msecs)
Definition: delay.c:2
u8 inb(u16 port)
void outb(u8 val, u16 port)
struct resource * new_resource(struct device *dev, unsigned int index)
See if a resource structure already exists for a given index and if not allocate one.
Definition: device_util.c:346
#define CHIP_NAME(X)
Definition: device.h:32
#define BIOS_INFO
BIOS_INFO - Expected events.
Definition: loglevel.h:113
unsigned int get_uint_option(const char *name, const unsigned int fallback)
Definition: option.c:116
void pmh7_touchpad_enable(int onoff)
Definition: pmh7.c:30
struct chip_operations ec_lenovo_pmh7_ops
Definition: pmh7.c:128
void pmh7_trackpoint_enable(int onoff)
Definition: pmh7.c:38
void pmh7_register_clear_bit(int reg, int bit)
Definition: pmh7.c:82
void pmh7_backlight_enable(int onoff)
Definition: pmh7.c:14
bool pmh7_dgpu_power_state(void)
Definition: pmh7.c:69
void pmh7_register_write(int reg, int val)
Definition: pmh7.c:97
void pmh7_dock_event_enable(int onoff)
Definition: pmh7.c:22
void pmh7_ultrabay_power_enable(int onoff)
Definition: pmh7.c:46
static void enable_dev(struct device *dev)
Definition: pmh7.c:104
void pmh7_dgpu_power_enable(int onoff)
Definition: pmh7.c:54
char pmh7_register_read(int reg)
Definition: pmh7.c:90
void pmh7_register_set_bit(int reg, int bit)
Definition: pmh7.c:74
#define EC_LENOVO_PMH7_DATA
Definition: pmh7.h:11
#define EC_LENOVO_PMH7_REG_REV
Definition: pmh7.h:14
#define EC_LENOVO_PMH7_INDEX
Definition: pmh7.h:6
#define EC_LENOVO_PMH7_REG_ID
Definition: pmh7.h:13
#define EC_LENOVO_PMH7_ADDR_L
Definition: pmh7.h:9
#define EC_LENOVO_PMH7_ADDR_H
Definition: pmh7.h:10
#define EC_LENOVO_PMH7_BASE
Definition: pmh7.h:8
#define IORESOURCE_IO
Definition: resource.h:9
#define IORESOURCE_FIXED
Definition: resource.h:36
Definition: device.h:107
DEVTREE_CONST void * chip_info
Definition: device.h:164
int dock_event_enable
Definition: chip.h:8
int backlight_enable
Definition: chip.h:7
unsigned long flags
Definition: resource.h:49
unsigned char align
Definition: resource.h:51
unsigned char gran
Definition: resource.h:52
resource_t base
Definition: resource.h:45
resource_t size
Definition: resource.h:46
u8 val
Definition: sys.c:300
void udelay(uint32_t us)
Definition: udelay.c:15