This patch adds a proper namestring generation to our ACPIgen generator.
Its used for Name and Scope and Processor now. As bonus, it allows to create a multi name paths too. Like Scope(\ALL.YOUR.BASE). Signed-off-by: Rudolf Marek <r.marek@assembler.cz> Acked-by: Stefan Reinauer <stepan@coresystems.de> git-svn-id: svn://svn.coreboot.org/coreboot/trunk@4368 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1
This commit is contained in:
parent
f17f647a62
commit
3310d75e6c
|
@ -147,22 +147,111 @@ int acpigen_emit_stream(char *data, int size)
|
||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* The NameString are bit tricky, each element can be 4 chars, if
|
||||||
|
less its padded with underscore. Check 18.2.2 and 18.4
|
||||||
|
and 5.3 of ACPI specs 3.0 for details
|
||||||
|
*/
|
||||||
|
|
||||||
|
static int acpigen_emit_simple_namestring(char *name) {
|
||||||
|
int i, len = 0;
|
||||||
|
char ud[] = "____";
|
||||||
|
for (i = 0; i < 4; i++) {
|
||||||
|
if ((name[i] == '\0') || (name[i] == '.')) {
|
||||||
|
len += acpigen_emit_stream(ud, 4 - i);
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
len += acpigen_emit_byte(name[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return len;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int acpigen_emit_double_namestring(char *name, int dotpos) {
|
||||||
|
int len = 0;
|
||||||
|
/* mark dual name prefix */
|
||||||
|
len += acpigen_emit_byte(0x2e);
|
||||||
|
len += acpigen_emit_simple_namestring(name);
|
||||||
|
len += acpigen_emit_simple_namestring(&name[dotpos + 1]);
|
||||||
|
return len;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int acpigen_emit_multi_namestring(char *name) {
|
||||||
|
int len = 0, count = 0;
|
||||||
|
unsigned char *pathlen;
|
||||||
|
/* mark multi name prefix */
|
||||||
|
len += acpigen_emit_byte(0x2f);
|
||||||
|
len += acpigen_emit_byte(0x0);
|
||||||
|
pathlen = ((unsigned char *) acpigen_get_current()) - 1;
|
||||||
|
|
||||||
|
while (name[0] != '\0') {
|
||||||
|
len += acpigen_emit_simple_namestring(name);
|
||||||
|
/* find end or next entity */
|
||||||
|
while ((name[0] != '.') && (name[0] != '\0'))
|
||||||
|
name++;
|
||||||
|
/* forward to next */
|
||||||
|
if (name[0] == '.')
|
||||||
|
name++;
|
||||||
|
count++;
|
||||||
|
}
|
||||||
|
|
||||||
|
pathlen[0] = count;
|
||||||
|
return len;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int acpigen_emit_namestring(char *namepath) {
|
||||||
|
int dotcount = 0, i;
|
||||||
|
int dotpos;
|
||||||
|
int len = 0;
|
||||||
|
|
||||||
|
/* we can start with a \ */
|
||||||
|
if (namepath[0] == '\\') {
|
||||||
|
len += acpigen_emit_byte('\\');
|
||||||
|
namepath++;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* and there can be any number of ^ */
|
||||||
|
while (namepath[0] == '^') {
|
||||||
|
len += acpigen_emit_byte('^');
|
||||||
|
namepath++;
|
||||||
|
}
|
||||||
|
|
||||||
|
ASSERT(namepath[0] != '\0');
|
||||||
|
|
||||||
|
i = 0;
|
||||||
|
while (namepath[i] != '\0') {
|
||||||
|
if (namepath[i] == '.') {
|
||||||
|
dotcount++;
|
||||||
|
dotpos = i;
|
||||||
|
}
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dotcount == 0) {
|
||||||
|
len += acpigen_emit_simple_namestring(namepath);
|
||||||
|
} else if (dotcount == 1) {
|
||||||
|
len += acpigen_emit_double_namestring(namepath, dotpos);
|
||||||
|
} else {
|
||||||
|
len += acpigen_emit_multi_namestring(namepath);
|
||||||
|
}
|
||||||
|
return len;
|
||||||
|
}
|
||||||
|
|
||||||
int acpigen_write_name(char *name)
|
int acpigen_write_name(char *name)
|
||||||
{
|
{
|
||||||
int len = strlen(name);
|
int len;
|
||||||
/* name op */
|
/* name op */
|
||||||
acpigen_emit_byte(0x8);
|
len = acpigen_emit_byte(0x8);
|
||||||
acpigen_emit_stream(name, len);
|
return len + acpigen_emit_namestring(name);
|
||||||
return len + 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int acpigen_write_scope(char *name)
|
int acpigen_write_scope(char *name)
|
||||||
{
|
{
|
||||||
int len;
|
int len;
|
||||||
/* scope op */
|
/* scope op */
|
||||||
acpigen_emit_byte(0x10);
|
len = acpigen_emit_byte(0x10);
|
||||||
len = acpigen_write_len_f();
|
len += acpigen_write_len_f();
|
||||||
return len + acpigen_emit_stream(name, strlen(name)) + 1;
|
return len + acpigen_emit_namestring(name);
|
||||||
}
|
}
|
||||||
|
|
||||||
int acpigen_write_processor(u8 cpuindex, u32 pblock_addr, u8 pblock_len)
|
int acpigen_write_processor(u8 cpuindex, u32 pblock_addr, u8 pblock_len)
|
||||||
|
@ -178,8 +267,8 @@ int acpigen_write_processor(u8 cpuindex, u32 pblock_addr, u8 pblock_len)
|
||||||
acpigen_emit_byte(0x83);
|
acpigen_emit_byte(0x83);
|
||||||
len = acpigen_write_len_f();
|
len = acpigen_write_len_f();
|
||||||
|
|
||||||
sprintf(pscope, "\\._PR_CPU%x", (unsigned int) cpuindex);
|
sprintf(pscope, "\\_PR.CPU%x", (unsigned int) cpuindex);
|
||||||
len += acpigen_emit_stream(pscope, strlen(pscope));
|
len += acpigen_emit_namestring(pscope);
|
||||||
acpigen_emit_byte(cpuindex);
|
acpigen_emit_byte(cpuindex);
|
||||||
acpigen_emit_byte(pblock_addr & 0xff);
|
acpigen_emit_byte(pblock_addr & 0xff);
|
||||||
acpigen_emit_byte((pblock_addr >> 8) & 0xff);
|
acpigen_emit_byte((pblock_addr >> 8) & 0xff);
|
||||||
|
@ -238,7 +327,7 @@ int acpigen_write_PPC(u8 nr)
|
||||||
/* method op */
|
/* method op */
|
||||||
acpigen_emit_byte(0x14);
|
acpigen_emit_byte(0x14);
|
||||||
len = acpigen_write_len_f();
|
len = acpigen_write_len_f();
|
||||||
len += acpigen_emit_stream("_PPC", 4);
|
len += acpigen_emit_namestring("_PPC");
|
||||||
/* no fnarg */
|
/* no fnarg */
|
||||||
acpigen_emit_byte(0x00);
|
acpigen_emit_byte(0x00);
|
||||||
/* return */
|
/* return */
|
||||||
|
|
|
@ -29,6 +29,7 @@ int acpigen_write_package(int nr_el);
|
||||||
int acpigen_write_byte(unsigned int data);
|
int acpigen_write_byte(unsigned int data);
|
||||||
int acpigen_emit_byte(unsigned char data);
|
int acpigen_emit_byte(unsigned char data);
|
||||||
int acpigen_emit_stream(char *data, int size);
|
int acpigen_emit_stream(char *data, int size);
|
||||||
|
int acpigen_emit_namestring(char *namepath);
|
||||||
int acpigen_write_dword(unsigned int data);
|
int acpigen_write_dword(unsigned int data);
|
||||||
int acpigen_write_qword(uint64_t data);
|
int acpigen_write_qword(uint64_t data);
|
||||||
int acpigen_write_name(char *name);
|
int acpigen_write_name(char *name);
|
||||||
|
|
|
@ -376,7 +376,7 @@ write_pstates:
|
||||||
|
|
||||||
int amd_model_fxx_generate_powernow(u32 pcontrol_blk, u8 plen, u8 onlyBSP) {
|
int amd_model_fxx_generate_powernow(u32 pcontrol_blk, u8 plen, u8 onlyBSP) {
|
||||||
int lens;
|
int lens;
|
||||||
char pscope[] = "\\_PR_";
|
char pscope[] = "\\_PR";
|
||||||
|
|
||||||
lens = acpigen_write_scope(pscope);
|
lens = acpigen_write_scope(pscope);
|
||||||
lens += pstates_algorithm(pcontrol_blk, plen, onlyBSP);
|
lens += pstates_algorithm(pcontrol_blk, plen, onlyBSP);
|
||||||
|
|
|
@ -270,7 +270,7 @@ int k8acpi_write_vars(void)
|
||||||
{
|
{
|
||||||
int lens;
|
int lens;
|
||||||
msr_t msr;
|
msr_t msr;
|
||||||
char pscope[] = "\\._SB_PCI0";
|
char pscope[] = "\\_SB.PCI0";
|
||||||
|
|
||||||
lens = acpigen_write_scope(pscope);
|
lens = acpigen_write_scope(pscope);
|
||||||
lens += k8acpi_write_pci_data(4, "BUSN", 0xe0);
|
lens += k8acpi_write_pci_data(4, "BUSN", 0xe0);
|
||||||
|
|
Loading…
Reference in New Issue