diff options
| author | Lubomir Rintel <lkundrak@v3.sk> | 2019-04-18 10:46:49 -0400 |
|---|---|---|
| committer | Sebastian Reichel <sebastian.reichel@collabora.com> | 2019-04-18 15:51:49 -0400 |
| commit | a7a9bacb9a32f9cebe5feda2e33064440f52d61d (patch) | |
| tree | ea85c0e3d40249f2d53ed9381057e777de976fd1 | |
| parent | 47e120d3337b83ac6de2ebc622b3c9b6c1a9f315 (diff) | |
x86/platform/olpc: Use a correct version when making up a battery node
The XO-1 and XO-1.5 batteries apparently differ in an ability to report
ambient temperature. We need to use a different compatible string for the
XO-1.5 battery.
Previously olpc_dt_fixup() used the presence of the battery node's
compatible property to decide whether the DT is up to date. Now we need
to look for a particular value in the compatible string, to decide
Signed-off-by: Lubomir Rintel <lkundrak@v3.sk>
Acked-by: Pavel Machek <pavel@ucw.cz>
Acked-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Sebastian Reichel <sebastian.reichel@collabora.com>
| -rw-r--r-- | arch/x86/platform/olpc/olpc_dt.c | 64 |
1 files changed, 50 insertions, 14 deletions
diff --git a/arch/x86/platform/olpc/olpc_dt.c b/arch/x86/platform/olpc/olpc_dt.c index 820236b511b3..0296c5b55e6f 100644 --- a/arch/x86/platform/olpc/olpc_dt.c +++ b/arch/x86/platform/olpc/olpc_dt.c | |||
| @@ -220,10 +220,26 @@ static u32 __init olpc_dt_get_board_revision(void) | |||
| 220 | return be32_to_cpu(rev); | 220 | return be32_to_cpu(rev); |
| 221 | } | 221 | } |
| 222 | 222 | ||
| 223 | int olpc_dt_compatible_match(phandle node, const char *compat) | ||
| 224 | { | ||
| 225 | char buf[64], *p; | ||
| 226 | int plen, len; | ||
| 227 | |||
| 228 | plen = olpc_dt_getproperty(node, "compatible", buf, sizeof(buf)); | ||
| 229 | if (plen <= 0) | ||
| 230 | return 0; | ||
| 231 | |||
| 232 | len = strlen(compat); | ||
| 233 | for (p = buf; p < buf + plen; p += strlen(p) + 1) { | ||
| 234 | if (strcmp(p, compat) == 0) | ||
| 235 | return 1; | ||
| 236 | } | ||
| 237 | |||
| 238 | return 0; | ||
| 239 | } | ||
| 240 | |||
| 223 | void __init olpc_dt_fixup(void) | 241 | void __init olpc_dt_fixup(void) |
| 224 | { | 242 | { |
| 225 | int r; | ||
| 226 | char buf[64]; | ||
| 227 | phandle node; | 243 | phandle node; |
| 228 | u32 board_rev; | 244 | u32 board_rev; |
| 229 | 245 | ||
| @@ -231,22 +247,31 @@ void __init olpc_dt_fixup(void) | |||
| 231 | if (!node) | 247 | if (!node) |
| 232 | return; | 248 | return; |
| 233 | 249 | ||
| 234 | /* | ||
| 235 | * If the battery node has a compatible property, we are running a new | ||
| 236 | * enough firmware and don't have fixups to make. | ||
| 237 | */ | ||
| 238 | r = olpc_dt_getproperty(node, "compatible", buf, sizeof(buf)); | ||
| 239 | if (r > 0) | ||
| 240 | return; | ||
| 241 | |||
| 242 | pr_info("PROM DT: Old firmware detected, applying fixes\n"); | ||
| 243 | |||
| 244 | board_rev = olpc_dt_get_board_revision(); | 250 | board_rev = olpc_dt_get_board_revision(); |
| 245 | if (!board_rev) | 251 | if (!board_rev) |
| 246 | return; | 252 | return; |
| 247 | 253 | ||
| 248 | if (board_rev >= olpc_board_pre(0xd0)) { | 254 | if (board_rev >= olpc_board_pre(0xd0)) { |
| 249 | /* XO-1.5: add dcon device */ | 255 | /* XO-1.5 */ |
| 256 | |||
| 257 | if (olpc_dt_compatible_match(node, "olpc,xo1.5-battery")) | ||
| 258 | return; | ||
| 259 | |||
| 260 | /* Add olpc,xo1.5-battery compatible marker to battery node */ | ||
| 261 | olpc_dt_interpret("\" /battery@0\" find-device"); | ||
| 262 | olpc_dt_interpret(" \" olpc,xo1.5-battery\" +compatible"); | ||
| 263 | olpc_dt_interpret("device-end"); | ||
| 264 | |||
| 265 | if (olpc_dt_compatible_match(node, "olpc,xo1-battery")) { | ||
| 266 | /* | ||
| 267 | * If we have a olpc,xo1-battery compatible, then we're | ||
| 268 | * running a new enough firmware that already has | ||
| 269 | * the dcon node. | ||
| 270 | */ | ||
| 271 | return; | ||
| 272 | } | ||
| 273 | |||
| 274 | /* Add dcon device */ | ||
| 250 | olpc_dt_interpret("\" /pci/display@1\" find-device"); | 275 | olpc_dt_interpret("\" /pci/display@1\" find-device"); |
| 251 | olpc_dt_interpret(" new-device"); | 276 | olpc_dt_interpret(" new-device"); |
| 252 | olpc_dt_interpret(" \" dcon\" device-name"); | 277 | olpc_dt_interpret(" \" dcon\" device-name"); |
| @@ -254,7 +279,18 @@ void __init olpc_dt_fixup(void) | |||
| 254 | olpc_dt_interpret(" finish-device"); | 279 | olpc_dt_interpret(" finish-device"); |
| 255 | olpc_dt_interpret("device-end"); | 280 | olpc_dt_interpret("device-end"); |
| 256 | } else { | 281 | } else { |
| 257 | /* XO-1: add dcon device, mark RTC as olpc,xo1-rtc */ | 282 | /* XO-1 */ |
| 283 | |||
| 284 | if (olpc_dt_compatible_match(node, "olpc,xo1-battery")) { | ||
| 285 | /* | ||
| 286 | * If we have a olpc,xo1-battery compatible, then we're | ||
| 287 | * running a new enough firmware that already has | ||
| 288 | * the dcon and RTC nodes. | ||
| 289 | */ | ||
| 290 | return; | ||
| 291 | } | ||
| 292 | |||
| 293 | /* Add dcon device, mark RTC as olpc,xo1-rtc */ | ||
| 258 | olpc_dt_interpret("\" /pci/display@1,1\" find-device"); | 294 | olpc_dt_interpret("\" /pci/display@1,1\" find-device"); |
| 259 | olpc_dt_interpret(" new-device"); | 295 | olpc_dt_interpret(" new-device"); |
| 260 | olpc_dt_interpret(" \" dcon\" device-name"); | 296 | olpc_dt_interpret(" \" dcon\" device-name"); |
