mirror of https://gitee.com/openkylin/linux.git
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>
This commit is contained in:
parent
47e120d333
commit
a7a9bacb9a
|
@ -220,10 +220,26 @@ static u32 __init olpc_dt_get_board_revision(void)
|
||||||
return be32_to_cpu(rev);
|
return be32_to_cpu(rev);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int olpc_dt_compatible_match(phandle node, const char *compat)
|
||||||
|
{
|
||||||
|
char buf[64], *p;
|
||||||
|
int plen, len;
|
||||||
|
|
||||||
|
plen = olpc_dt_getproperty(node, "compatible", buf, sizeof(buf));
|
||||||
|
if (plen <= 0)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
len = strlen(compat);
|
||||||
|
for (p = buf; p < buf + plen; p += strlen(p) + 1) {
|
||||||
|
if (strcmp(p, compat) == 0)
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
void __init olpc_dt_fixup(void)
|
void __init olpc_dt_fixup(void)
|
||||||
{
|
{
|
||||||
int r;
|
|
||||||
char buf[64];
|
|
||||||
phandle node;
|
phandle node;
|
||||||
u32 board_rev;
|
u32 board_rev;
|
||||||
|
|
||||||
|
@ -231,22 +247,31 @@ void __init olpc_dt_fixup(void)
|
||||||
if (!node)
|
if (!node)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
/*
|
|
||||||
* If the battery node has a compatible property, we are running a new
|
|
||||||
* enough firmware and don't have fixups to make.
|
|
||||||
*/
|
|
||||||
r = olpc_dt_getproperty(node, "compatible", buf, sizeof(buf));
|
|
||||||
if (r > 0)
|
|
||||||
return;
|
|
||||||
|
|
||||||
pr_info("PROM DT: Old firmware detected, applying fixes\n");
|
|
||||||
|
|
||||||
board_rev = olpc_dt_get_board_revision();
|
board_rev = olpc_dt_get_board_revision();
|
||||||
if (!board_rev)
|
if (!board_rev)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (board_rev >= olpc_board_pre(0xd0)) {
|
if (board_rev >= olpc_board_pre(0xd0)) {
|
||||||
/* XO-1.5: add dcon device */
|
/* XO-1.5 */
|
||||||
|
|
||||||
|
if (olpc_dt_compatible_match(node, "olpc,xo1.5-battery"))
|
||||||
|
return;
|
||||||
|
|
||||||
|
/* Add olpc,xo1.5-battery compatible marker to battery node */
|
||||||
|
olpc_dt_interpret("\" /battery@0\" find-device");
|
||||||
|
olpc_dt_interpret(" \" olpc,xo1.5-battery\" +compatible");
|
||||||
|
olpc_dt_interpret("device-end");
|
||||||
|
|
||||||
|
if (olpc_dt_compatible_match(node, "olpc,xo1-battery")) {
|
||||||
|
/*
|
||||||
|
* If we have a olpc,xo1-battery compatible, then we're
|
||||||
|
* running a new enough firmware that already has
|
||||||
|
* the dcon node.
|
||||||
|
*/
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Add dcon device */
|
||||||
olpc_dt_interpret("\" /pci/display@1\" find-device");
|
olpc_dt_interpret("\" /pci/display@1\" find-device");
|
||||||
olpc_dt_interpret(" new-device");
|
olpc_dt_interpret(" new-device");
|
||||||
olpc_dt_interpret(" \" dcon\" device-name");
|
olpc_dt_interpret(" \" dcon\" device-name");
|
||||||
|
@ -254,7 +279,18 @@ void __init olpc_dt_fixup(void)
|
||||||
olpc_dt_interpret(" finish-device");
|
olpc_dt_interpret(" finish-device");
|
||||||
olpc_dt_interpret("device-end");
|
olpc_dt_interpret("device-end");
|
||||||
} else {
|
} else {
|
||||||
/* XO-1: add dcon device, mark RTC as olpc,xo1-rtc */
|
/* XO-1 */
|
||||||
|
|
||||||
|
if (olpc_dt_compatible_match(node, "olpc,xo1-battery")) {
|
||||||
|
/*
|
||||||
|
* If we have a olpc,xo1-battery compatible, then we're
|
||||||
|
* running a new enough firmware that already has
|
||||||
|
* the dcon and RTC nodes.
|
||||||
|
*/
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Add dcon device, mark RTC as olpc,xo1-rtc */
|
||||||
olpc_dt_interpret("\" /pci/display@1,1\" find-device");
|
olpc_dt_interpret("\" /pci/display@1,1\" find-device");
|
||||||
olpc_dt_interpret(" new-device");
|
olpc_dt_interpret(" new-device");
|
||||||
olpc_dt_interpret(" \" dcon\" device-name");
|
olpc_dt_interpret(" \" dcon\" device-name");
|
||||||
|
|
Loading…
Reference in New Issue