Patrick Georgi | ac95903 | 2020-05-05 22:49:26 +0200 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-or-later */ |
Sergej Ivanov | d777c78 | 2015-04-03 18:10:27 +0300 | [diff] [blame] | 2 | |
Sergej Ivanov | d777c78 | 2015-04-03 18:10:27 +0300 | [diff] [blame] | 3 | #include <arch/pirq_routing.h> |
| 4 | |
| 5 | const struct irq_routing_table intel_irq_routing_table = { |
| 6 | PIRQ_SIGNATURE, /* u32 signature */ |
| 7 | PIRQ_VERSION, /* u16 version */ |
| 8 | 32 + 16 * 10, /* Max. number of devices on the bus */ |
| 9 | 0x00, /* Interrupt router bus */ |
| 10 | (0x14 << 3) | 0x3, /* Interrupt router dev */ |
| 11 | 0, /* IRQs devoted exclusively to PCI usage */ |
| 12 | 0x1002, /* Vendor */ |
| 13 | 0x439d, /* Device */ |
| 14 | 0, /* Miniport */ |
| 15 | { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }, /* u8 rfu[11] */ |
| 16 | 0xa6, /* Checksum (has to be set to some value that |
| 17 | * would give 0 after the sum of all bytes |
| 18 | * for this structure (including checksum). |
Elyes HAOUAS | f4df9d1 | 2016-09-23 17:57:38 +0200 | [diff] [blame] | 19 | */ |
Patrick Georgi | 7155595 | 2021-02-11 14:40:01 +0100 | [diff] [blame] | 20 | /* clang-format off */ |
Sergej Ivanov | d777c78 | 2015-04-03 18:10:27 +0300 | [diff] [blame] | 21 | { |
| 22 | /* bus, dev | fn, {link, bitmap}, {link, bitmap}, {link, bitmap}, {link, bitmap}, slot, rfu */ |
| 23 | {0x00, (0x00 << 3) | 0x0, {{0x01, 0xccb0}, {0x02, 0xccb0}, {0x03, 0xccb0}, {0x04, 0xdab8}}, 0x0, 0x0}, |
| 24 | {0x00, (0x01 << 3) | 0x0, {{0x05, 0xccb0}, {0x06, 0xccb0}, {0x07, 0xccb0}, {0x08, 0xccb0}}, 0x0, 0x0}, |
| 25 | {0x00, (0x02 << 3) | 0x0, {{0x05, 0xccb0}, {0x06, 0xccb0}, {0x07, 0xccb0}, {0x08, 0xccb0}}, 0x0, 0x0}, |
| 26 | {0x00, (0x14 << 3) | 0x0, {{0x01, 0xccb0}, {0x02, 0xccb0}, {0x03, 0xccb0}, {0x04, 0xdab8}}, 0x0, 0x0}, |
| 27 | {0x00, (0x12 << 3) | 0x0, {{0x03, 0xccb0}, {0x02, 0xccb0}, {0x00, 0x0000}, {0x00, 0x0000}}, 0x0, 0x0}, |
| 28 | {0x00, (0x13 << 3) | 0x0, {{0x03, 0xccb0}, {0x02, 0xccb0}, {0x00, 0x0000}, {0x00, 0x0000}}, 0x0, 0x0}, |
| 29 | {0x00, (0x16 << 3) | 0x0, {{0x03, 0xccb0}, {0x02, 0xccb0}, {0x00, 0x0000}, {0x00, 0x0000}}, 0x0, 0x0}, |
| 30 | {0x00, (0x10 << 3) | 0x0, {{0x03, 0xccb0}, {0x00, 0x0000}, {0x00, 0x0000}, {0x00, 0x0000}}, 0x0, 0x0}, |
| 31 | {0x00, (0x11 << 3) | 0x0, {{0x04, 0xdab8}, {0x00, 0x0000}, {0x00, 0x0000}, {0x00, 0x0000}}, 0x0, 0x0}, |
| 32 | {0x01, (0x00 << 3) | 0x0, {{0x05, 0xccb0}, {0x06, 0xccb0}, {0x07, 0xccb0}, {0x08, 0xccb0}}, 0x12, 0x0}, |
| 33 | } |
Patrick Georgi | 7155595 | 2021-02-11 14:40:01 +0100 | [diff] [blame] | 34 | /* clang-format on */ |
Sergej Ivanov | d777c78 | 2015-04-03 18:10:27 +0300 | [diff] [blame] | 35 | }; |
| 36 | |
| 37 | unsigned long write_pirq_routing_table(unsigned long addr) |
| 38 | { |
| 39 | return copy_pirq_routing_table(addr, &intel_irq_routing_table); |
| 40 | } |