Angel Pons | 3ef916f | 2020-04-02 23:49:13 +0200 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-only */ |
Stefan Reinauer | 9aea04a | 2012-03-30 12:01:06 -0700 | [diff] [blame] | 2 | |
| 3 | #ifndef __CHROMEOS_H__ |
| 4 | #define __CHROMEOS_H__ |
| 5 | |
Aaron Durbin | 790e3ad | 2014-01-27 15:08:27 -0600 | [diff] [blame] | 6 | #include <stddef.h> |
Aaron Durbin | fd79562 | 2013-03-01 17:12:26 -0600 | [diff] [blame] | 7 | #include <stdint.h> |
Cheng-Yi Chiang | cfde82c | 2019-10-14 12:10:51 +0800 | [diff] [blame] | 8 | #include <types.h> |
Aaron Durbin | fd79562 | 2013-03-01 17:12:26 -0600 | [diff] [blame] | 9 | |
Julius Werner | cd49cce | 2019-03-05 16:53:33 -0800 | [diff] [blame] | 10 | #if CONFIG(CHROMEOS) |
Julius Werner | 105f5b7 | 2015-01-21 17:39:49 -0800 | [diff] [blame] | 11 | /* functions implemented in watchdog.c */ |
Julius Werner | c713594 | 2016-03-23 16:08:11 -0700 | [diff] [blame] | 12 | void mark_watchdog_tombstone(void); |
Julius Werner | 105f5b7 | 2015-01-21 17:39:49 -0800 | [diff] [blame] | 13 | void reboot_from_watchdog(void); |
Kyösti Mälkki | 662353a | 2021-02-11 07:18:29 +0200 | [diff] [blame] | 14 | bool reset_watchdog_tombstone(void); |
Duncan Laurie | 203e8ce | 2014-04-22 10:52:31 -0700 | [diff] [blame] | 15 | #else |
Julius Werner | c713594 | 2016-03-23 16:08:11 -0700 | [diff] [blame] | 16 | static inline void mark_watchdog_tombstone(void) { return; } |
Julius Werner | 105f5b7 | 2015-01-21 17:39:49 -0800 | [diff] [blame] | 17 | static inline void reboot_from_watchdog(void) { return; } |
Duncan Laurie | 203e8ce | 2014-04-22 10:52:31 -0700 | [diff] [blame] | 18 | #endif /* CONFIG_CHROMEOS */ |
Stefan Reinauer | 9aea04a | 2012-03-30 12:01:06 -0700 | [diff] [blame] | 19 | |
Keith Short | e0f3400 | 2019-02-05 16:15:10 -0700 | [diff] [blame] | 20 | /** |
| 21 | * Perform any platform specific actions required prior to resetting the Cr50. |
| 22 | * Defined as weak function in cr50_enable_update.c |
| 23 | */ |
| 24 | void mainboard_prepare_cr50_reset(void); |
Duncan Laurie | f131fc7 | 2019-01-23 15:01:21 -0800 | [diff] [blame] | 25 | |
Vadim Bendebury | 318708d | 2014-10-23 16:02:51 -0700 | [diff] [blame] | 26 | void cbmem_add_vpd_calibration_data(void); |
Kyösti Mälkki | 1749b77 | 2020-12-19 16:19:44 +0200 | [diff] [blame] | 27 | void chromeos_set_me_hash(u32*, int); |
Kyösti Mälkki | 8a1fcf4 | 2021-02-12 18:43:36 +0200 | [diff] [blame] | 28 | void chromeos_set_ramoops(void *ram_oops, size_t size); |
Subrata Banik | 73505f1 | 2023-12-27 21:13:25 +0530 | [diff] [blame] | 29 | /* |
| 30 | * The factory config space is a one-time programmable info page. |
| 31 | * For the unprovisioned one, the read will be 0x0. |
| 32 | * Return `-1` in case of error. |
| 33 | */ |
| 34 | int64_t chromeos_get_factory_config(void); |
Subrata Banik | d968b85 | 2023-12-28 23:37:27 +0530 | [diff] [blame^] | 35 | /* |
| 36 | * Determines whether a ChromeOS device is branded as a Chromebook Plus |
| 37 | * based on specific bit flags: |
| 38 | * |
| 39 | * - Bit 4 (0x10): Indicates whether the device chassis has the |
| 40 | * "chromebook-plus" branding. |
| 41 | * - Bits 3-0 (0x1): Must be 0x1 to signify compliance with Chromebook Plus |
| 42 | * hardware specifications. |
| 43 | * |
| 44 | * To be considered a Chromebook Plus, either of these conditions needs to be met. |
| 45 | */ |
| 46 | bool chromeos_device_branded_plus(void); |
Vadim Bendebury | 318708d | 2014-10-23 16:02:51 -0700 | [diff] [blame] | 47 | |
Aaron Durbin | b0f8151 | 2016-07-25 21:31:41 -0500 | [diff] [blame] | 48 | /* |
Jon Murphy | c4e9045 | 2022-06-28 10:36:23 -0600 | [diff] [blame] | 49 | * Declaration for mainboards to use to generate ACPI-specific ChromeOS needs. |
Aaron Durbin | b0f8151 | 2016-07-25 21:31:41 -0500 | [diff] [blame] | 50 | */ |
Kyösti Mälkki | 4fdd84e | 2021-11-02 10:36:20 +0200 | [diff] [blame] | 51 | void chromeos_acpi_gpio_generate(void); |
Aaron Durbin | b0f8151 | 2016-07-25 21:31:41 -0500 | [diff] [blame] | 52 | |
| 53 | enum { |
| 54 | CROS_GPIO_REC = 1, /* Recovery */ |
Joel Kitching | 1d94849 | 2019-03-27 18:26:28 +0800 | [diff] [blame] | 55 | CROS_GPIO_DEPRECATED_DEV = 2, /* Developer; |
| 56 | * deprecated (chromium:942901) */ |
Aaron Durbin | b0f8151 | 2016-07-25 21:31:41 -0500 | [diff] [blame] | 57 | CROS_GPIO_WP = 3, /* Write Protect */ |
Aaron Durbin | 73deeae | 2016-12-12 13:57:11 -0600 | [diff] [blame] | 58 | CROS_GPIO_PE = 4, /* Phase enforcement for final product */ |
Aaron Durbin | b0f8151 | 2016-07-25 21:31:41 -0500 | [diff] [blame] | 59 | |
| 60 | CROS_GPIO_ACTIVE_LOW = 0, |
| 61 | CROS_GPIO_ACTIVE_HIGH = 1, |
| 62 | |
| 63 | CROS_GPIO_VIRTUAL = -1, |
| 64 | }; |
| 65 | |
| 66 | struct cros_gpio { |
| 67 | int type; |
| 68 | int polarity; |
| 69 | int gpio_num; |
| 70 | const char *device; |
| 71 | }; |
| 72 | |
| 73 | #define CROS_GPIO_INITIALIZER(typ, pol, num, dev) \ |
| 74 | { \ |
| 75 | .type = (typ), \ |
| 76 | .polarity = (pol), \ |
| 77 | .gpio_num = (num), \ |
| 78 | .device = (dev), \ |
| 79 | } |
| 80 | |
| 81 | #define CROS_GPIO_REC_INITIALIZER(pol, num, dev) \ |
| 82 | CROS_GPIO_INITIALIZER(CROS_GPIO_REC, pol, num, dev) |
| 83 | |
| 84 | #define CROS_GPIO_REC_AL(num, dev) \ |
| 85 | CROS_GPIO_REC_INITIALIZER(CROS_GPIO_ACTIVE_LOW, num, dev) |
| 86 | |
| 87 | #define CROS_GPIO_REC_AH(num, dev) \ |
| 88 | CROS_GPIO_REC_INITIALIZER(CROS_GPIO_ACTIVE_HIGH, num, dev) |
| 89 | |
Aaron Durbin | b0f8151 | 2016-07-25 21:31:41 -0500 | [diff] [blame] | 90 | #define CROS_GPIO_WP_INITIALIZER(pol, num, dev) \ |
| 91 | CROS_GPIO_INITIALIZER(CROS_GPIO_WP, pol, num, dev) |
| 92 | |
| 93 | #define CROS_GPIO_WP_AL(num, dev) \ |
| 94 | CROS_GPIO_WP_INITIALIZER(CROS_GPIO_ACTIVE_LOW, num, dev) |
| 95 | |
| 96 | #define CROS_GPIO_WP_AH(num, dev) \ |
| 97 | CROS_GPIO_WP_INITIALIZER(CROS_GPIO_ACTIVE_HIGH, num, dev) |
| 98 | |
Aaron Durbin | 73deeae | 2016-12-12 13:57:11 -0600 | [diff] [blame] | 99 | #define CROS_GPIO_PE_INITIALIZER(pol, num, dev) \ |
| 100 | CROS_GPIO_INITIALIZER(CROS_GPIO_PE, pol, num, dev) |
| 101 | |
| 102 | #define CROS_GPIO_PE_AL(num, dev) \ |
| 103 | CROS_GPIO_PE_INITIALIZER(CROS_GPIO_ACTIVE_LOW, num, dev) |
| 104 | |
| 105 | #define CROS_GPIO_PE_AH(num, dev) \ |
| 106 | CROS_GPIO_PE_INITIALIZER(CROS_GPIO_ACTIVE_HIGH, num, dev) |
| 107 | |
Kyösti Mälkki | 4ff218a | 2021-11-02 13:03:06 +0200 | [diff] [blame] | 108 | struct cros_gpio_pack { |
| 109 | int count; |
| 110 | const struct cros_gpio *gpios; |
| 111 | }; |
| 112 | |
| 113 | extern const struct cros_gpio_pack variant_cros_gpio; |
| 114 | |
| 115 | #define DECLARE_NO_CROS_GPIOS() \ |
| 116 | const struct cros_gpio_pack variant_cros_gpio = \ |
| 117 | { .count = 0, .gpios = NULL } |
| 118 | |
| 119 | #define DECLARE_CROS_GPIOS(x) \ |
| 120 | const struct cros_gpio_pack variant_cros_gpio = \ |
| 121 | { .count = ARRAY_SIZE(x), .gpios = x } |
| 122 | |
| 123 | #define DECLARE_WEAK_CROS_GPIOS(x) \ |
| 124 | const struct cros_gpio_pack __weak variant_cros_gpio = \ |
| 125 | { .count = ARRAY_SIZE(x), .gpios = x } |
Kyösti Mälkki | 4fdd84e | 2021-11-02 10:36:20 +0200 | [diff] [blame] | 126 | |
Daisuke Nojiri | 742fc8d | 2014-10-10 10:51:06 -0700 | [diff] [blame] | 127 | #endif /* __CHROMEOS_H__ */ |