diff options
-rw-r--r-- | src/ec/lenovo/h8/Makefile.inc | 1 | ||||
-rw-r--r-- | src/ec/lenovo/h8/chip.h | 4 | ||||
-rw-r--r-- | src/ec/lenovo/h8/h8.c | 13 | ||||
-rw-r--r-- | src/ec/lenovo/h8/h8.h | 4 | ||||
-rw-r--r-- | src/ec/lenovo/h8/wwan.c | 67 |
5 files changed, 77 insertions, 12 deletions
diff --git a/src/ec/lenovo/h8/Makefile.inc b/src/ec/lenovo/h8/Makefile.inc index 18aca17fbf..3d218fde74 100644 --- a/src/ec/lenovo/h8/Makefile.inc +++ b/src/ec/lenovo/h8/Makefile.inc @@ -7,6 +7,7 @@ endif ramstage-y += h8.c ramstage-y += bluetooth.c +ramstage-y += wwan.c smm-y += smm.c endif diff --git a/src/ec/lenovo/h8/chip.h b/src/ec/lenovo/h8/chip.h index d62312d197..25512bc3b3 100644 --- a/src/ec/lenovo/h8/chip.h +++ b/src/ec/lenovo/h8/chip.h @@ -47,9 +47,13 @@ struct ec_lenovo_h8_config { u8 has_power_management_beeps; u8 has_uwb; u8 has_bdc_detection; + u8 has_wwan_detection; u8 bdc_gpio_num; u8 bdc_gpio_lvl; + + u8 wwan_gpio_num; + u8 wwan_gpio_lvl; }; #endif /* EC_LENOVO_H8EC_CHIP_H */ diff --git a/src/ec/lenovo/h8/h8.c b/src/ec/lenovo/h8/h8.c index 6f14953ced..882ac0271c 100644 --- a/src/ec/lenovo/h8/h8.c +++ b/src/ec/lenovo/h8/h8.c @@ -44,15 +44,6 @@ void h8_wlan_enable(int on) ec_clr_bit(0x3a, 5); } -/* Controls radio-off pin in WWAN MiniPCIe slot. */ -static void h8_wwan_enable(int on) -{ - if (on) - ec_set_bit(0x3a, 6); - else - ec_clr_bit(0x3a, 6); -} - /* Controls radio-off pin in UWB MiniPCIe slot. */ static void h8_uwb_enable(int on) { @@ -283,9 +274,7 @@ static void h8_enable(struct device *dev) val = h8_has_bdc(dev) && h8_bluetooth_nv_enable(); h8_bluetooth_enable(val); - if (get_option(&val, "wwan") != CB_SUCCESS) - val = 1; - + val = h8_has_wwan(dev) && h8_wwan_nv_enable(); h8_wwan_enable(val); if (conf->has_uwb) { diff --git a/src/ec/lenovo/h8/h8.h b/src/ec/lenovo/h8/h8.h index 4b7d3a036b..19b9cf60d2 100644 --- a/src/ec/lenovo/h8/h8.h +++ b/src/ec/lenovo/h8/h8.h @@ -35,6 +35,10 @@ void h8_bluetooth_enable(int on); bool h8_bluetooth_nv_enable(void); bool h8_has_bdc(struct device *dev); +void h8_wwan_enable(int on); +bool h8_wwan_nv_enable(void); +bool h8_has_wwan(struct device *dev); + /* EC registers */ #define H8_CONFIG0 0x00 #define H8_CONFIG0_EVENTS_ENABLE 0x02 diff --git a/src/ec/lenovo/h8/wwan.c b/src/ec/lenovo/h8/wwan.c new file mode 100644 index 0000000000..cf3c8f7cf0 --- /dev/null +++ b/src/ec/lenovo/h8/wwan.c @@ -0,0 +1,67 @@ +/* + * 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 <southbridge/intel/common/gpio.h> +#include <console/console.h> +#include <device/device.h> +#include <ec/acpi/ec.h> +#include <option.h> + +#include "h8.h" +#include "chip.h" + +/* Controls radio-off pin in WWAN MiniPCIe slot. */ +void h8_wwan_enable(int on) +{ + if (on) + ec_set_bit(0x3a, 6); + else + ec_clr_bit(0x3a, 6); +} + +/* + * Detect WWAN on supported MBs. + */ +bool h8_has_wwan(struct device *dev) +{ + struct ec_lenovo_h8_config *conf = dev->chip_info; + + if (!conf->has_wwan_detection) { + printk(BIOS_INFO, "H8: WWAN detection not implemented. " + "Assuming WWAN installed\n"); + return true; + } + + if (get_gpio(conf->wwan_gpio_num) == conf->wwan_gpio_lvl) { + printk(BIOS_INFO, "H8: WWAN installed\n"); + return true; + } + + printk(BIOS_INFO, "H8: WWAN not installed\n"); + return false; +} + +/* + * Return WWAN NVRAM setting. + */ +bool h8_wwan_nv_enable(void) +{ + u8 val; + + if (get_option(&val, "wwan") != CB_SUCCESS) + return true; + + return val; +} |