Tim Wawrzynczak has posted comments on this change. ( https://review.coreboot.org/c/coreboot/+/39121 )
Change subject: mb/google/dedede: configure ESPI IO decode range for chrome EC ......................................................................
Patch Set 2: Code-Review+2
Patch Set 2:
(1 comment)
Patch Set 2:
(1 comment)
Patch Set 2:
LGTM, but just a thought, do we want to move the LPC generic IO decode ranges to our EC driver? Then we don't have to keep adding it to every mainboard's devicetree.
This I/O decode range configuration seems to be Intel SoC specific - not the range itself, but the register value. So moving to the EC driver may be tricky and might require SoC knowledge in there.
Actually, these are the I/O windows that Chrome EC uses -- 0x800, 0x900, 0x200. The way they get mapped to LPC I/O regs is specific to Intel, but I think we can do some work to avoid having to duplicate this across mainboards. I believe this was done differently on APL/GLK, but it still required mainboard to provide a function to do the work.
Sure, but to my knowledge, LPC/eSPI is x86-specific anyway, ARM uses i2c or spi. So, the ec_lpc enable() function should be able to program the ranges that it uses. I would think Wilco would be the only outlier here, besides maybe some ancient boards (I see butterly, parrot stout have different ranges?)