Nico Huber | 53ec8c5 | 2020-03-21 19:50:26 +0100 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-only */ |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 2 | |
| 3 | /* |
| 4 | * Pseudo device that contains methods to modify Opregion |
| 5 | * "Mailbox 3 BIOS to Driver Notification" |
| 6 | * The BIOS to Driver Notification mailbox is intended to support |
| 7 | * BIOS to Driver event notification or data storage for BIOS to |
| 8 | * Driver data synchronization purpose. |
| 9 | */ |
| 10 | Device (BOX3) |
| 11 | { |
| 12 | Name (_ADR, 0) |
| 13 | |
| 14 | OperationRegion (OPRG, SystemMemory, ASLS, 0x2000) |
| 15 | Field (OPRG, DWordAcc, NoLock, Preserve) |
| 16 | { |
| 17 | // OpRegion Header |
| 18 | Offset (0x58), |
| 19 | MBOX, 32, |
| 20 | |
| 21 | // Mailbox 3 |
| 22 | Offset (0x300), |
| 23 | ARDY, 1, /* Offset 0 Driver readiness */ |
| 24 | , 31, |
| 25 | ASLC, 32, /* Offset 4 ASLE interrupt command / status */ |
| 26 | TCHE, 32, /* Offset 8 Technology enabled indicator */ |
| 27 | ALSI, 32, /* Offset 12 Current ALS illuminance reading */ |
| 28 | BCLP, 32, /* Offset 16 Backlight britness to set */ |
| 29 | PFIT, 32, /* Offset 20 Panel fitting Request */ |
| 30 | CBLV, 32, /* Offset 24 Brightness Current State */ |
| 31 | } |
| 32 | |
| 33 | /* |
| 34 | * Request back-light brightness change through mailbox 3 |
| 35 | * |
| 36 | * @param Arg0 The brightness level to set in percent |
Felix Singer | 9df60d3 | 2022-12-26 09:43:07 +0100 | [diff] [blame^] | 37 | * @Return 0 on success, Ones on failure |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 38 | * Errors: * ASLS is zero |
| 39 | * * Mailbox 3 support not advertised |
| 40 | * * Driver not loaded or not ready |
| 41 | * * Driver reported an error during ASLE IRQ |
| 42 | */ |
Nico Huber | c48d883 | 2018-08-23 22:36:09 +0200 | [diff] [blame] | 43 | Method (XBCM, 1, Serialized) |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 44 | { |
Felix Singer | 6041543 | 2022-01-02 00:43:21 +0100 | [diff] [blame] | 45 | If (ASLS == 0) |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 46 | { |
| 47 | Return (Ones) |
| 48 | } |
Felix Singer | d252776 | 2022-12-16 07:54:16 +0100 | [diff] [blame] | 49 | If (MBOX & 4 == 0) |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 50 | { |
| 51 | Return (Ones) |
| 52 | } |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 53 | |
Nico Huber | 58344fc | 2018-08-23 21:52:05 +0200 | [diff] [blame] | 54 | /* Always keep BCLP up to date, even if driver is not ready. |
| 55 | It requires a full 8-bit brightness value. 255 = 100% */ |
Felix Singer | 52f4652 | 2022-12-12 02:25:37 +0100 | [diff] [blame] | 56 | Local1 = Arg0 * 255 / 100 |
Felix Singer | fa9e31b | 2022-01-02 01:53:54 +0100 | [diff] [blame] | 57 | If (Local1 > 255) { |
Felix Singer | 52f4652 | 2022-12-12 02:25:37 +0100 | [diff] [blame] | 58 | Local1 = 255 |
Alexander Couzens | 661907c | 2018-08-23 16:40:55 +0200 | [diff] [blame] | 59 | } |
Nico Huber | 58344fc | 2018-08-23 21:52:05 +0200 | [diff] [blame] | 60 | /* also set valid bit */ |
Felix Singer | 274fa64 | 2022-12-16 04:27:21 +0100 | [diff] [blame] | 61 | BCLP = Local1 | 0x80000000 |
Alexander Couzens | 661907c | 2018-08-23 16:40:55 +0200 | [diff] [blame] | 62 | |
Felix Singer | 6041543 | 2022-01-02 00:43:21 +0100 | [diff] [blame] | 63 | If (ARDY == 0) |
Nico Huber | 58344fc | 2018-08-23 21:52:05 +0200 | [diff] [blame] | 64 | { |
| 65 | Return (Ones) |
| 66 | } |
| 67 | |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 68 | /* Request back-light change */ |
Felix Singer | 52f4652 | 2022-12-12 02:25:37 +0100 | [diff] [blame] | 69 | ASLC = 0x2 |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 70 | /* Trigger IRQ */ |
Felix Singer | 52f4652 | 2022-12-12 02:25:37 +0100 | [diff] [blame] | 71 | ASLE = 0x1 |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 72 | |
Felix Singer | 52f4652 | 2022-12-12 02:25:37 +0100 | [diff] [blame] | 73 | Local0 = 0x20 |
Felix Singer | fa9e31b | 2022-01-02 01:53:54 +0100 | [diff] [blame] | 74 | While (Local0 > 0) |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 75 | { |
| 76 | Sleep (1) |
Felix Singer | d252776 | 2022-12-16 07:54:16 +0100 | [diff] [blame] | 77 | If (ASLC & 2 == 0) { |
Nico Huber | c48d883 | 2018-08-23 22:36:09 +0200 | [diff] [blame] | 78 | /* Request has been processed, check status: */ |
Felix Singer | 35e65a8 | 2022-12-16 07:11:17 +0100 | [diff] [blame] | 79 | Local1 = (ASLC >> 12) & 3 |
Felix Singer | 6041543 | 2022-01-02 00:43:21 +0100 | [diff] [blame] | 80 | If (Local1 == 0) { |
Felix Singer | 9df60d3 | 2022-12-26 09:43:07 +0100 | [diff] [blame^] | 81 | Return (0) |
Nico Huber | c48d883 | 2018-08-23 22:36:09 +0200 | [diff] [blame] | 82 | } Else { |
| 83 | Return (Ones) |
| 84 | } |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 85 | } |
Felix Singer | 66e2630 | 2021-12-31 14:13:47 +0100 | [diff] [blame] | 86 | Local0-- |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 87 | } |
| 88 | |
| 89 | Return (Ones) |
| 90 | } |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 91 | } |
| 92 | |
| 93 | /* |
| 94 | * Pseudo device that contains methods to operate on GTT memory |
| 95 | */ |
| 96 | Device (LEGA) |
| 97 | { |
| 98 | Name (_ADR, 0) |
| 99 | |
Nico Huber | f26a7c7 | 2018-08-23 22:14:01 +0200 | [diff] [blame] | 100 | /* Divide round closest */ |
| 101 | Method (DRCL, 2) |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 102 | { |
Felix Singer | b232ca6 | 2021-12-31 12:12:18 +0100 | [diff] [blame] | 103 | Return ((Arg0 + Arg1 / 2) / Arg1) |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 104 | } |
| 105 | |
Nico Huber | f26a7c7 | 2018-08-23 22:14:01 +0200 | [diff] [blame] | 106 | Method (XBCM, 1, NotSerialized) |
| 107 | { |
Felix Singer | 52f4652 | 2022-12-12 02:25:37 +0100 | [diff] [blame] | 108 | BCLV = DRCL (Arg0 * BCLM, 100) |
Nico Huber | f26a7c7 | 2018-08-23 22:14:01 +0200 | [diff] [blame] | 109 | } |
| 110 | |
| 111 | /* Find value closest to BCLV in BRIG (which must be ordered) */ |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 112 | Method (XBQC, 0, NotSerialized) |
| 113 | { |
Patrick Rudolph | 6dc488a | 2020-02-28 10:38:55 +0100 | [diff] [blame] | 114 | /* Prevent DivideByZero if backlight control isn't enabled */ |
| 115 | If (BCLM == 0) |
| 116 | { |
Felix Singer | 9df60d3 | 2022-12-26 09:43:07 +0100 | [diff] [blame^] | 117 | Return (0) |
Patrick Rudolph | 6dc488a | 2020-02-28 10:38:55 +0100 | [diff] [blame] | 118 | } |
Nico Huber | f26a7c7 | 2018-08-23 22:14:01 +0200 | [diff] [blame] | 119 | /* Local0: current percentage */ |
Felix Singer | 52f4652 | 2022-12-12 02:25:37 +0100 | [diff] [blame] | 120 | Local0 = DRCL (BCLV * 100, BCLM) |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 121 | |
Nico Huber | f26a7c7 | 2018-08-23 22:14:01 +0200 | [diff] [blame] | 122 | /* Local1: loop index (selectable values start at 2 in BRIG) */ |
Felix Singer | 52f4652 | 2022-12-12 02:25:37 +0100 | [diff] [blame] | 123 | Local1 = 2 |
Felix Singer | 04e6893 | 2022-01-02 01:46:20 +0100 | [diff] [blame] | 124 | While (Local1 < SizeOf (BRIG) - 1) { |
Nico Huber | f26a7c7 | 2018-08-23 22:14:01 +0200 | [diff] [blame] | 125 | /* Local[23]: adjacent values in BRIG */ |
Felix Singer | 52f4652 | 2022-12-12 02:25:37 +0100 | [diff] [blame] | 126 | Local2 = DeRefOf (BRIG[Local1]) |
| 127 | Local3 = DeRefOf (BRIG[Local1 + 1]) |
Nico Huber | f26a7c7 | 2018-08-23 22:14:01 +0200 | [diff] [blame] | 128 | |
Felix Singer | 04e6893 | 2022-01-02 01:46:20 +0100 | [diff] [blame] | 129 | If (Local0 < Local3) { |
| 130 | If (Local0 < Local2 || Local0 - Local2 < Local3 - Local0) { |
Nico Huber | f26a7c7 | 2018-08-23 22:14:01 +0200 | [diff] [blame] | 131 | Return (Local2) |
| 132 | } Else { |
| 133 | Return (Local3) |
| 134 | } |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 135 | } |
Nico Huber | f26a7c7 | 2018-08-23 22:14:01 +0200 | [diff] [blame] | 136 | |
Felix Singer | 42fcf5a | 2021-12-31 13:49:03 +0100 | [diff] [blame] | 137 | Local1++ |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 138 | } |
Nico Huber | f26a7c7 | 2018-08-23 22:14:01 +0200 | [diff] [blame] | 139 | |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 140 | /* Didn't find greater/equal value: use the last */ |
Nico Huber | f26a7c7 | 2018-08-23 22:14:01 +0200 | [diff] [blame] | 141 | Return (Local3) |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 142 | } |
| 143 | } |
| 144 | |
Nico Huber | d5842f5 | 2015-09-24 17:45:45 +0200 | [diff] [blame] | 145 | Method (XBCM, 1, NotSerialized) |
| 146 | { |
Felix Singer | 6041543 | 2022-01-02 00:43:21 +0100 | [diff] [blame] | 147 | If (^BOX3.XBCM (Arg0) == Ones) |
Patrick Rudolph | 6838aae | 2018-07-29 10:53:01 +0200 | [diff] [blame] | 148 | { |
| 149 | ^LEGA.XBCM (Arg0) |
| 150 | } |
Nico Huber | d5842f5 | 2015-09-24 17:45:45 +0200 | [diff] [blame] | 151 | } |
| 152 | |
| 153 | Method (XBQC, 0, NotSerialized) |
| 154 | { |
Nico Huber | f26a7c7 | 2018-08-23 22:14:01 +0200 | [diff] [blame] | 155 | /* |
| 156 | * Always query the hardware directly. Not all OS drivers |
| 157 | * keep CBLV up to date (one is Linux' i915). Some years |
| 158 | * after that is fixed we can probably use CBLV? |
| 159 | */ |
| 160 | Return (^LEGA.XBQC ()) |
Nico Huber | d5842f5 | 2015-09-24 17:45:45 +0200 | [diff] [blame] | 161 | } |