47b7b3402b
This change adds support to sconfig for generating the firmware configuration field and option definitions in devicetree.cb. In addition these fields and options can be used to probe for a device and have that device be disabled if it is not found at boot time. New tokens: fw_config: top level token, table can be defined before chips field: define field in the mask with the start and end bits option: define option in a field with the value of the field probe: indicate that a device should probe by field and option Example: fw_config field FEATURE 0 0 option DISABLE 0 option ENABLE 1 end end chip drivers/generic/feature device generic 0 on probe FEATURE ENABLE end end Variants can add new fields and add new options to existing fields in overridetree.cb but cannot redefine an existing option. Devices can have multiple probe tokens, and the device will be considered to be found if any of them return true. The output from defining this field are: 1) the various fields and options will be added as macro constants to static.h and can be used by fw_config for probing. 2) the probe entries will result in a list of fields/options to probe that is added to the resulting struct device and handled by coreboot. BUG=b:147462631 Signed-off-by: Duncan Laurie <dlaurie@google.com> Change-Id: I8aea63e577d933aea09e0d0b09470929cc96e0de Reviewed-on: https://review.coreboot.org/c/coreboot/+/41440 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Furquan Shaikh <furquan@google.com>
55 lines
2.4 KiB
Text
Executable file
55 lines
2.4 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);}
|
|
fw_config {return(FW_CONFIG_TABLE);}
|
|
field {return(FW_CONFIG_FIELD);}
|
|
option {return(FW_CONFIG_OPTION);}
|
|
probe {return(FW_CONFIG_PROBE);}
|
|
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);}
|
|
%%
|