Sooner or later, some board was going to need extra FW_CONFIG bits for
a field that was already in production, so this patch adds support for
adding extra (unused) bits to a field.
The extra are appended via a syntax like:
`field FIELD_NAME START0 END0 | START1 END1 | START2 END2 ...`
and the suffixed bits are all treated as if they are contiguous when
defining option values.
BUG=b:185190978
TEST=Modified volteer fw_config to the following:
field AUDIO 8 10 | 29 29 | 31 31
option NONE 0
option MAX98357_ALC5682I_I2S 1
option MAX98373_ALC5682I_I2S 2
option MAX98373_ALC5682_SNDW 3
option MAX98373_ALC5682I_I2S_UP4 4
option MAX98360_ALC5682I_I2S 5
option RT1011_ALC5682I_I2S 6
option AUDIO_FOO 7
option AUDIO_BAR 8
option AUDIO_QUUX 9
option AUDIO_BLAH1 10
option AUDIO_BLAH2 15
option AUDIO_BLAH3 16
option AUDIO_BLAH4 31
end
which yielded (in static_fw_config.h):
FW_CONFIG_FIELD_AUDIO_MASK 0xa0000700
FW_CONFIG_FIELD_AUDIO_OPTION_NONE_VALUE 0x0
FW_CONFIG_FIELD_AUDIO_OPTION_MAX98357_ALC5682I_I2S_VALUE 0x100
FW_CONFIG_FIELD_AUDIO_OPTION_MAX98373_ALC5682I_I2S_VALUE 0x200
FW_CONFIG_FIELD_AUDIO_OPTION_MAX98373_ALC5682_SNDW_VALUE 0x300
FW_CONFIG_FIELD_AUDIO_OPTION_MAX98373_ALC5682I_I2S_UP4_VALUE 0x400
FW_CONFIG_FIELD_AUDIO_OPTION_MAX98360_ALC5682I_I2S_VALUE 0x500
FW_CONFIG_FIELD_AUDIO_OPTION_RT1011_ALC5682I_I2S_VALUE 0x600
FW_CONFIG_FIELD_AUDIO_OPTION_AUDIO_FOO_VALUE 0x700
FW_CONFIG_FIELD_AUDIO_OPTION_AUDIO_BAR_VALUE 0x20000000
FW_CONFIG_FIELD_AUDIO_OPTION_AUDIO_QUUX_VALUE 0x20000100
FW_CONFIG_FIELD_AUDIO_OPTION_AUDIO_BLAH1_VALUE 0x20000200
FW_CONFIG_FIELD_AUDIO_OPTION_AUDIO_BLAH2_VALUE 0x20000700
FW_CONFIG_FIELD_AUDIO_OPTION_AUDIO_BLAH3_VALUE 0x80000000
FW_CONFIG_FIELD_AUDIO_OPTION_AUDIO_BLAH4_VALUE 0xa0000700
Change-Id: I5ed76706347ee9642198efc77139abdc3af1b8a6
Signed-off-by: Tim Wawrzynczak <twawrzynczak@chromium.org>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/52747
Reviewed-by: Duncan Laurie <duncan@iceblink.org>
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
61 lines
2.6 KiB
Text
Executable file
61 lines
2.6 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);}
|
|
alias {return(ALIAS);}
|
|
use {return(REFERENCE);}
|
|
ref {return(REFERENCE);}
|
|
as {return(ASSOCIATION);}
|
|
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);}
|
|
gpio {yylval.number=GPIO; 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);}
|
|
\| {return(PIPE);}
|
|
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);}
|
|
%%
|