Comments
Patch
===================================================================
@@ -0,0 +1 @@
+source src/ec/lenovo/pmh7/Kconfig
===================================================================
@@ -0,0 +1 @@
+subdirs-$(CONFIG_EC_LENOVO_PMH7) += pmh7
===================================================================
@@ -0,0 +1,2 @@
+config EC_LENOVO_PMH7
+ bool
===================================================================
@@ -0,0 +1,13 @@
+#ifndef EC_LENOVO_PMH7_H
+#define EC_LENOVO_PMH7_H
+
+#define EC_LENOVO_PMH7_BASE 0x15e0
+#define EC_LENOVO_PMH7_ADDR (EC_LENOVO_PMH7_BASE + 0x0c)
+#define EC_LENOVO_PMH7_DATA (EC_LENOVO_PMH7_BASE + 0x0e)
+
+void pmh7_register_set_bit(int reg, int bit);
+void pmh7_register_clear_bit(int reg, int bit);
+char pmh7_register_read(int reg);
+void pmh7_register_write(int reg, int val);
+
+#endif
===================================================================
@@ -0,0 +1 @@
+driver-y += pmh7.c
===================================================================
@@ -0,0 +1,56 @@
+#include <arch/io.h>
+#include <console/console.h>
+#include <device/device.h>
+#include <device/pnp.h>
+#include <stdlib.h>
+
+#include "pmh7.h"
+
+void pmh7_register_set_bit(int reg, int bit)
+{
+ char val;
+
+ outb(reg, EC_LENOVO_PMH7_ADDR);
+ val = inb(EC_LENOVO_PMH7_DATA);
+ outb(reg, EC_LENOVO_PMH7_ADDR);
+ outb(val | (1 << bit), EC_LENOVO_PMH7_DATA);
+}
+
+void pmh7_register_clear_bit(int reg, int bit)
+{
+ char val;
+
+ outb(reg, EC_LENOVO_PMH7_ADDR);
+ val = inb(EC_LENOVO_PMH7_DATA);
+ outb(reg, EC_LENOVO_PMH7_ADDR);
+ outb(val &= ~(1 << bit), EC_LENOVO_PMH7_DATA);
+}
+
+char pmh7_register_read(int reg)
+{
+ outb(reg, EC_LENOVO_PMH7_ADDR);
+ return inb(EC_LENOVO_PMH7_DATA);
+}
+
+void pmh7_register_write(int reg, int val)
+{
+ outb(reg, EC_LENOVO_PMH7_ADDR);
+ outb(val, EC_LENOVO_PMH7_DATA);
+}
+
+static void enable_dev(device_t dev)
+{
+ struct resource *resource;
+ resource = new_resource(dev, 0x77);
+ resource->flags = IORESOURCE_IO | IORESOURCE_FIXED;
+ resource->base = EC_LENOVO_PMH7_BASE;
+ resource->size = 16;
+ resource->align = 5;
+ resource->gran = 5;
+
+}
+
+struct chip_operations ec_lenovo_pmh7_ops = {
+ CHIP_NAME("Lenovo Power Management Hardware Hub 7")
+ .enable_dev = enable_dev,
+};