2008-01-18 16:08:58 +01:00
|
|
|
#ifndef COREBOOT_TABLES_H
|
|
|
|
#define COREBOOT_TABLES_H
|
2003-04-22 21:02:15 +02:00
|
|
|
|
2015-09-08 20:34:43 +02:00
|
|
|
#include <commonlib/coreboot_tables.h>
|
chromeos: Simplify fill_lb_gpios even further
A long time ago many Chrome OS boards had pages full of duplicated
boilerplate code for the fill_lb_gpios() function, and we spent a lot of
time bikeshedding a proper solution that passes a table of lb_gpio
structs which can be concisely written with a static struct initializer
in http://crosreview.com/234648. Unfortunately we never really finished
that patch and in the mean time a different solution using the
fill_lb_gpio() helper got standardized onto most boards.
Still, that solution is not quite as clean and concise as the one we had
already designed, and it also wasn't applied consistently to all recent
boards (causing more boards with bad code to get added afterwards). This
patch switches all boards newer than Link to the better solution and
also adds some nicer debug output for the GPIOs while I'm there.
If more boards need to be converted from fill_lb_gpio() to this model
later (e.g. from a branch), it's quite easy to do with:
s/fill_lb_gpio(gpio++,\n\?\s*\([^,]*\),\n\?\s*\([^,]*\),\n\?\s*\([^,]*\),\n\?\s*\([^,]*\));/\t{\1, \2, \4, \3},/
Based on a patch by Furquan Shaikh <furquan@google.com>.
BUG=None
BRANCH=None
TEST=Booted on Oak. Ran abuild -x.
Change-Id: I449974d1c75c8ed187f5e10935495b2f03725811
Signed-off-by: Julius Werner <jwerner@chromium.org>
Reviewed-on: https://review.coreboot.org/14226
Tested-by: build bot (Jenkins)
Reviewed-by: David Hendricks <dhendrix@chromium.org>
2016-04-01 02:27:05 +02:00
|
|
|
#include <stddef.h>
|
2013-03-20 22:08:04 +01:00
|
|
|
/* function prototypes for building the coreboot table */
|
|
|
|
|
2016-04-20 00:06:09 +02:00
|
|
|
/*
|
|
|
|
* Write forwarding table of target address at entry address returning size
|
|
|
|
* of table written.
|
|
|
|
*/
|
|
|
|
size_t write_coreboot_forwarding_table(uintptr_t entry, uintptr_t target);
|
|
|
|
|
2013-03-20 22:08:04 +01:00
|
|
|
void fill_lb_gpios(struct lb_gpios *gpios);
|
chromeos: Simplify fill_lb_gpios even further
A long time ago many Chrome OS boards had pages full of duplicated
boilerplate code for the fill_lb_gpios() function, and we spent a lot of
time bikeshedding a proper solution that passes a table of lb_gpio
structs which can be concisely written with a static struct initializer
in http://crosreview.com/234648. Unfortunately we never really finished
that patch and in the mean time a different solution using the
fill_lb_gpio() helper got standardized onto most boards.
Still, that solution is not quite as clean and concise as the one we had
already designed, and it also wasn't applied consistently to all recent
boards (causing more boards with bad code to get added afterwards). This
patch switches all boards newer than Link to the better solution and
also adds some nicer debug output for the GPIOs while I'm there.
If more boards need to be converted from fill_lb_gpio() to this model
later (e.g. from a branch), it's quite easy to do with:
s/fill_lb_gpio(gpio++,\n\?\s*\([^,]*\),\n\?\s*\([^,]*\),\n\?\s*\([^,]*\),\n\?\s*\([^,]*\));/\t{\1, \2, \4, \3},/
Based on a patch by Furquan Shaikh <furquan@google.com>.
BUG=None
BRANCH=None
TEST=Booted on Oak. Ran abuild -x.
Change-Id: I449974d1c75c8ed187f5e10935495b2f03725811
Signed-off-by: Julius Werner <jwerner@chromium.org>
Reviewed-on: https://review.coreboot.org/14226
Tested-by: build bot (Jenkins)
Reviewed-by: David Hendricks <dhendrix@chromium.org>
2016-04-01 02:27:05 +02:00
|
|
|
void lb_add_gpios(struct lb_gpios *gpios, const struct lb_gpio *gpio_table,
|
|
|
|
size_t count);
|
2013-03-20 22:08:04 +01:00
|
|
|
|
2014-03-15 00:32:55 +01:00
|
|
|
void uart_fill_lb(void *data);
|
|
|
|
void lb_add_serial(struct lb_serial *serial, void *data);
|
|
|
|
void lb_add_console(uint16_t consoletype, void *data);
|
|
|
|
|
2013-08-28 00:48:32 +02:00
|
|
|
/* Define this in mainboard.c to add board-specific table entries. */
|
|
|
|
void lb_board(struct lb_header *header);
|
|
|
|
|
2017-05-17 04:39:50 +02:00
|
|
|
/* Define this function to fill in the frame buffer returning 0 on success and
|
|
|
|
< 0 on error. */
|
|
|
|
int fill_lb_framebuffer(struct lb_framebuffer *framebuffer);
|
2015-10-02 01:06:47 +02:00
|
|
|
|
2016-02-10 17:52:47 +01:00
|
|
|
/* Allow arch to add records. */
|
|
|
|
void lb_arch_add_records(struct lb_header *header);
|
|
|
|
|
2014-10-16 22:02:37 +02:00
|
|
|
/*
|
|
|
|
* Function to retrieve MAC address(es) from the VPD and store them in the
|
|
|
|
* coreboot table.
|
|
|
|
*/
|
|
|
|
void lb_table_add_macs_from_vpd(struct lb_header *header);
|
|
|
|
|
2015-03-11 23:53:10 +01:00
|
|
|
void lb_table_add_serialno_from_vpd(struct lb_header *header);
|
|
|
|
|
2013-08-28 00:48:32 +02:00
|
|
|
struct lb_record *lb_new_record(struct lb_header *header);
|
|
|
|
|
2008-01-18 16:08:58 +01:00
|
|
|
#endif /* COREBOOT_TABLES_H */
|