c88b537461
Signed-off-by: Jon Dufresne <jon.dufresne@gmail.com> Acked-by: Uwe Hermann <uwe@hermann-uwe.de> git-svn-id: svn://svn.coreboot.org/coreboot/trunk@3189 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1
75 lines
2.8 KiB
C
75 lines
2.8 KiB
C
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include "pirq_routing.h"
|
|
|
|
static char *preamble[] = {
|
|
"/* This file was generated by getpir.c, do not modify!\n",
|
|
" * (but if you do, please run checkpir on it to verify)\n",
|
|
" *\n",
|
|
" * Contains the IRQ Routing Table dumped directly from your\n",
|
|
" * memory, which BIOS sets up.\n",
|
|
" *\n",
|
|
" * Documentation at: http://www.microsoft.com/whdc/archive/pciirq.mspx\n */\n\n",
|
|
"#ifdef GETPIR\n",
|
|
"#include \"pirq_routing.h\"\n",
|
|
"#else\n"
|
|
"#include <arch/pirq_routing.h>\n",
|
|
"#endif\n\n"
|
|
"const struct irq_routing_table intel_irq_routing_table = {\n",
|
|
"\tPIRQ_SIGNATURE, /* u32 signature */\n",
|
|
"\tPIRQ_VERSION, /* u16 version */\n",
|
|
0
|
|
};
|
|
|
|
void code_gen(char *filename, struct irq_routing_table *rt)
|
|
{
|
|
char **code = preamble;
|
|
struct irq_info *se_arr = (struct irq_info *) ((char *) rt + 32);
|
|
int i, ts = (rt->size - 32) / 16;
|
|
FILE *fpir;
|
|
|
|
if ((fpir = fopen(filename, "w")) == NULL) {
|
|
printf("Failed creating file!\n");
|
|
exit(2);
|
|
}
|
|
|
|
while (*code)
|
|
fprintf(fpir, "%s", *code++);
|
|
|
|
fprintf(fpir, "\t32+16*%d, /* There can be total %d devices on the bus */\n",
|
|
ts, ts);
|
|
fprintf(fpir, "\t0x%02x, /* Where the interrupt router lies (bus) */\n",
|
|
rt->rtr_bus);
|
|
fprintf(fpir, "\t(0x%02x<<3)|0x%01x, /* Where the interrupt router lies (dev) */\n",
|
|
rt->rtr_devfn >> 3, rt->rtr_devfn & 7);
|
|
fprintf(fpir, "\t%#x, /* IRQs devoted exclusively to PCI usage */\n",
|
|
rt->exclusive_irqs);
|
|
fprintf(fpir, "\t%#x, /* Vendor */\n", rt->rtr_vendor);
|
|
fprintf(fpir, "\t%#x, /* Device */\n", rt->rtr_device);
|
|
fprintf(fpir, "\t%#x, /* Crap (miniport) */\n",
|
|
rt->miniport_data);
|
|
fprintf(fpir, "\t{ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }, /* u8 rfu[11] */\n");
|
|
fprintf(fpir, "\t%#x, /* u8 checksum. This has to be set to some\n value that would give 0 after the sum of all\n bytes for this structure (including checksum) */\n",
|
|
rt->checksum);
|
|
fprintf(fpir, "\t{\n");
|
|
fprintf(fpir, "\t\t/* bus, dev|fn, {link, bitmap}, {link, bitmap}, {link, bitmap}, {link, bitmap}, slot, rfu */\n");
|
|
for (i = 0; i < ts; i++) {
|
|
fprintf(fpir, "\t\t{0x%02x,(0x%02x<<3)|0x%01x, {{0x%02x, 0x%04x}, {0x%02x, 0x%04x}, {0x%02x, 0x%04x}, {0x%02x, 0x0%04x}}, 0x%x, 0x%x},\n",
|
|
(se_arr+i)->bus, (se_arr+i)->devfn >> 3,
|
|
(se_arr+i)->devfn & 7, (se_arr+i)->irq[0].link,
|
|
(se_arr+i)->irq[0].bitmap, (se_arr+i)->irq[1].link,
|
|
(se_arr+i)->irq[1].bitmap, (se_arr+i)->irq[2].link,
|
|
(se_arr+i)->irq[2].bitmap, (se_arr+i)->irq[3].link,
|
|
(se_arr+i)->irq[3].bitmap, (se_arr+i)->slot,
|
|
(se_arr+i)->rfu);
|
|
}
|
|
fprintf(fpir, "\t}\n");
|
|
fprintf(fpir, "};\n");
|
|
|
|
fprintf(fpir, "\nunsigned long write_pirq_routing_table(unsigned long addr)\n");
|
|
fprintf(fpir, "{\n");
|
|
fprintf(fpir, "\treturn copy_pirq_routing_table(addr);\n");
|
|
fprintf(fpir, "}\n");
|
|
|
|
fclose(fpir);
|
|
}
|