3f3f53cd5e
Picasso has an LPC and eSPI bridge on the same PCI DEVFN. They can both be active at the same time. This adds a way to specify which devices belong on which bus. i.e., device pci 14.3 on # - D14F3 bridge device espi 0 on chip ec/google/chromeec device pnp 0c09.0 on end end end device lpc 0 on end end BUG=b:154445472 TEST=Built trembyle and saw static.c contained the espi bus. Signed-off-by: Raul E Rangel <rrangel@chromium.org> Change-Id: I0c2f40813c05680f72e5f30cbb13617e8f994841 Reviewed-on: https://review.coreboot.org/c/coreboot/+/41099 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Aaron Durbin <adurbin@chromium.org>
51 lines
2.3 KiB
Text
Executable file
51 lines
2.3 KiB
Text
Executable file
%{
|
|
/* sconfig, coreboot device tree compiler */
|
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
|
|
#include "sconfig.tab.h"
|
|
|
|
int linenum = 0;
|
|
%}
|
|
%option nodebug
|
|
%%
|
|
[ \t]+ {}
|
|
#.*\n {linenum++;}
|
|
\r?\n {linenum++;}
|
|
chip {return(CHIP);}
|
|
device {return(DEVICE);}
|
|
register {return(REGISTER);}
|
|
on {yylval.number=1; return(BOOL);}
|
|
off {yylval.number=0; return(BOOL);}
|
|
hidden {yylval.number=3; return(STATUS);}
|
|
mandatory {yylval.number=5; return(STATUS);}
|
|
pci {yylval.number=PCI; return(BUS);}
|
|
ioapic {yylval.number=IOAPIC; return(BUS);}
|
|
pnp {yylval.number=PNP; return(BUS);}
|
|
i2c {yylval.number=I2C; return(BUS);}
|
|
lapic {yylval.number=APIC; return(BUS);}
|
|
cpu_cluster {yylval.number=CPU_CLUSTER; return(BUS);}
|
|
cpu {yylval.number=CPU; return(BUS);}
|
|
domain {yylval.number=DOMAIN; return(BUS);}
|
|
generic {yylval.number=GENERIC; return(BUS);}
|
|
mmio {yylval.number=MMIO; return(BUS);}
|
|
spi {yylval.number=SPI; return(BUS);}
|
|
usb {yylval.number=USB; return(BUS);}
|
|
lpc {yylval.number=LPC; return(BUS);}
|
|
espi {yylval.number=ESPI; return(BUS);}
|
|
irq {yylval.number=IRQ; return(RESOURCE);}
|
|
drq {yylval.number=DRQ; return(RESOURCE);}
|
|
io {yylval.number=IO; return(RESOURCE);}
|
|
ioapic_irq {return(IOAPIC_IRQ);}
|
|
inherit {return(INHERIT);}
|
|
subsystemid {return(SUBSYSTEMID);}
|
|
end {return(END);}
|
|
smbios_slot_desc {return(SLOT_DESC);}
|
|
= {return(EQUALS);}
|
|
0x[0-9a-fA-F.]+ {yylval.string = malloc(yyleng+1); strncpy(yylval.string, yytext, yyleng); yylval.string[yyleng]='\0'; return(NUMBER);}
|
|
[0-9.]+ {yylval.string = malloc(yyleng+1); strncpy(yylval.string, yytext, yyleng); yylval.string[yyleng]='\0'; return(NUMBER);}
|
|
[0-9a-fA-F.]+ {yylval.string = malloc(yyleng+1); strncpy(yylval.string, yytext, yyleng); yylval.string[yyleng]='\0'; return(NUMBER);}
|
|
INT[A-D] {yylval.string = malloc(yyleng+1); strncpy(yylval.string, yytext, yyleng); yylval.string[yyleng]='\0'; return(PCIINT);}
|
|
\"\"[^\"]+\"\" {yylval.string = malloc(yyleng-1); strncpy(yylval.string, yytext+1, yyleng-2); yylval.string[yyleng-2]='\0'; return(STRING);}
|
|
\"[^\"]+\" {yylval.string = malloc(yyleng-1); strncpy(yylval.string, yytext+1, yyleng-2); yylval.string[yyleng-2]='\0'; return(STRING);}
|
|
[^ \n\t]+ {yylval.string = malloc(yyleng+1); strncpy(yylval.string, yytext, yyleng); yylval.string[yyleng]='\0'; return(STRING);}
|
|
%%
|