Page Menu
Home
FreeBSD
Search
Configure Global Search
Log In
Files
F151122352
D28278.id97521.diff
No One
Temporary
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Flag For Later
Award Token
Size
2 KB
Referenced Files
None
Subscribers
None
D28278.id97521.diff
View Options
diff --git a/usr.sbin/bhyve/pci_emul.c b/usr.sbin/bhyve/pci_emul.c
--- a/usr.sbin/bhyve/pci_emul.c
+++ b/usr.sbin/bhyve/pci_emul.c
@@ -106,6 +106,16 @@
static uint64_t pci_emul_membase64;
static uint64_t pci_emul_memlim64;
+struct pci_bar_allocation {
+ TAILQ_ENTRY(pci_bar_allocation) chain;
+ struct pci_devinst *pdi;
+ int idx;
+ enum pcibar_type type;
+ uint64_t size;
+};
+TAILQ_HEAD(pci_bar_list, pci_bar_allocation) pci_bars = TAILQ_HEAD_INITIALIZER(
+ pci_bars);
+
#define PCI_EMUL_IOBASE 0x2000
#define PCI_EMUL_IOLIMIT 0x10000
@@ -634,10 +644,6 @@
pci_emul_alloc_bar(struct pci_devinst *pdi, int idx, enum pcibar_type type,
uint64_t size)
{
- int error;
- uint64_t *baseptr, limit, addr, mask, lobits, bar;
- uint16_t cmd, enbit;
-
assert(idx >= 0 && idx <= PCI_BARMAX);
if ((size & (size - 1)) != 0)
@@ -652,6 +658,44 @@
size = 16;
}
+ /* allocate new bar */
+ struct pci_bar_allocation *const new_bar = calloc(1,
+ sizeof(struct pci_bar_allocation));
+ new_bar->pdi = pdi;
+ new_bar->idx = idx;
+ new_bar->type = type;
+ new_bar->size = size;
+
+ /* get bar position */
+ struct pci_bar_allocation *bar = NULL;
+ TAILQ_FOREACH (bar, &pci_bars, chain) {
+ if (bar->size < size) {
+ break;
+ }
+ }
+
+ /* insert bar into queue */
+ if (bar == NULL) {
+ TAILQ_INSERT_TAIL(&pci_bars, new_bar, chain);
+ } else {
+ TAILQ_INSERT_BEFORE(bar, new_bar, chain);
+ }
+
+ return (0);
+}
+
+static int
+pci_emul_assign_bar(const struct pci_bar_allocation *const pci_bar)
+{
+ struct pci_devinst *pdi = pci_bar->pdi;
+ const int idx = pci_bar->idx;
+ const enum pcibar_type type = pci_bar->type;
+ const uint64_t size = pci_bar->size;
+
+ int error;
+ uint64_t *baseptr, limit, addr, mask, lobits, bar;
+ uint16_t cmd, enbit;
+
switch (type) {
case PCIBAR_NONE:
baseptr = NULL;
@@ -1182,6 +1226,7 @@
bi->membase32 = pci_emul_membase32;
bi->membase64 = pci_emul_membase64;
+ /* first run: init devices */
for (slot = 0; slot < MAXSLOTS; slot++) {
si = &bi->slotinfo[slot];
for (func = 0; func < MAXFUNCS; func++) {
@@ -1221,6 +1266,18 @@
}
}
+ /* second run: assign BARs */
+ struct pci_bar_allocation *bar;
+ TAILQ_FOREACH (bar, &pci_bars, chain) {
+ pci_emul_assign_bar(bar);
+ }
+ /* free BARs */
+ while (!TAILQ_EMPTY(&pci_bars)) {
+ bar = TAILQ_FIRST(&pci_bars);
+ TAILQ_REMOVE(&pci_bars, bar, chain);
+ free(bar);
+ }
+
/*
* Add some slop to the I/O and memory resources decoded by
* this bus to give a guest some flexibility if it wants to
File Metadata
Details
Attached
Mime Type
text/plain
Expires
Tue, Apr 7, 5:52 AM (15 h, 6 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
31014088
Default Alt Text
D28278.id97521.diff (2 KB)
Attached To
Mode
D28278: bhyve: enumerate BARs by size
Attached
Detach File
Event Timeline
Log In to Comment