util/sconfig: Emit chip config pointers for PCI devices on root bus
This change emits chip config pointers for PCI devices on root bus in static_devices.h so that the config structure can be accessed directly without having to reference the device structure. This allows the linker to optimize out unused parts of the device tree from early stages like bootblock. Change-Id: I1d42e926dbfae14b889ade6dda363d8607974cae Signed-off-by: Furquan Shaikh <furquan@google.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/49214 Reviewed-by: Angel Pons <th3fanbus@gmail.com> Reviewed-by: Nico Huber <nico.h@gmx.de> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
parent
696f4ea0f5
commit
fceca9259b
1 changed files with 20 additions and 5 deletions
|
@ -1085,12 +1085,9 @@ static void emit_dev_links(FILE *fil, struct device *ptr)
|
||||||
fprintf(fil, "\t};\n");
|
fprintf(fil, "\t};\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
static void pass1(FILE *fil, FILE *head, struct device *ptr, struct device *next)
|
static struct chip_instance *get_chip_instance(const struct device *dev)
|
||||||
{
|
{
|
||||||
int pin;
|
struct chip_instance *chip_ins = dev->chip_instance;
|
||||||
struct chip_instance *chip_ins = ptr->chip_instance;
|
|
||||||
int has_children = dev_has_children(ptr);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If the chip instance of device has base_chip_instance pointer set, then follow that
|
* If the chip instance of device has base_chip_instance pointer set, then follow that
|
||||||
* to update the chip instance for current device.
|
* to update the chip instance for current device.
|
||||||
|
@ -1098,6 +1095,15 @@ static void pass1(FILE *fil, FILE *head, struct device *ptr, struct device *next
|
||||||
if (chip_ins->base_chip_instance)
|
if (chip_ins->base_chip_instance)
|
||||||
chip_ins = chip_ins->base_chip_instance;
|
chip_ins = chip_ins->base_chip_instance;
|
||||||
|
|
||||||
|
return chip_ins;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void pass1(FILE *fil, FILE *head, struct device *ptr, struct device *next)
|
||||||
|
{
|
||||||
|
int pin;
|
||||||
|
struct chip_instance *chip_ins = get_chip_instance(ptr);
|
||||||
|
int has_children = dev_has_children(ptr);
|
||||||
|
|
||||||
/* Emit probe structures. */
|
/* Emit probe structures. */
|
||||||
if (ptr->probe && (emit_fw_config_probe(fil, ptr) < 0)) {
|
if (ptr->probe && (emit_fw_config_probe(fil, ptr) < 0)) {
|
||||||
if (head)
|
if (head)
|
||||||
|
@ -1209,12 +1215,21 @@ static void pass1(FILE *fil, FILE *head, struct device *ptr, struct device *next
|
||||||
|
|
||||||
static void expose_device_names(FILE *fil, FILE *head, struct device *ptr, struct device *next)
|
static void expose_device_names(FILE *fil, FILE *head, struct device *ptr, struct device *next)
|
||||||
{
|
{
|
||||||
|
struct chip_instance *chip_ins = get_chip_instance(ptr);
|
||||||
|
|
||||||
/* Only devices on root bus here. */
|
/* Only devices on root bus here. */
|
||||||
if (ptr->bustype == PCI && ptr->parent->dev->bustype == DOMAIN) {
|
if (ptr->bustype == PCI && ptr->parent->dev->bustype == DOMAIN) {
|
||||||
fprintf(head, "extern DEVTREE_CONST struct device *const __pci_0_%02x_%d;\n",
|
fprintf(head, "extern DEVTREE_CONST struct device *const __pci_0_%02x_%d;\n",
|
||||||
ptr->path_a, ptr->path_b);
|
ptr->path_a, ptr->path_b);
|
||||||
fprintf(fil, "DEVTREE_CONST struct device *const __pci_0_%02x_%d = &%s;\n",
|
fprintf(fil, "DEVTREE_CONST struct device *const __pci_0_%02x_%d = &%s;\n",
|
||||||
ptr->path_a, ptr->path_b, ptr->name);
|
ptr->path_a, ptr->path_b, ptr->name);
|
||||||
|
|
||||||
|
if (chip_ins->chip->chiph_exists) {
|
||||||
|
fprintf(head, "extern DEVTREE_CONST void *const __pci_0_%02x_%d_config;\n",
|
||||||
|
ptr->path_a, ptr->path_b);
|
||||||
|
fprintf(fil, "DEVTREE_CONST void *const __pci_0_%02x_%d_config = &%s_info_%d;\n",
|
||||||
|
ptr->path_a, ptr->path_b, chip_ins->chip->name_underscore, chip_ins->id);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ptr->bustype == PNP) {
|
if (ptr->bustype == PNP) {
|
||||||
|
|
Loading…
Reference in a new issue