git://scm.lunaixsky.com
/
lunaix-os.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
rewrite the device subsystem interfaces (#48)
[lunaix-os.git]
/
lunaix-os
/
hal
/
gfxa
/
vga
/
vga_pci.c
diff --git
a/lunaix-os/hal/gfxa/vga/vga_pci.c
b/lunaix-os/hal/gfxa/vga/vga_pci.c
index 1109e5a3f222415a2c72f511680eb6e82f77bd5c..af4f228d6472fd1b3dbf8e28943dcb54de1c83ff 100644
(file)
--- a/
lunaix-os/hal/gfxa/vga/vga_pci.c
+++ b/
lunaix-os/hal/gfxa/vga/vga_pci.c
@@
-58,22
+58,26
@@
static u32_t palette[] = {
#define VGA_REG_OFF 0x0400
static int
#define VGA_REG_OFF 0x0400
static int
-vga_pci_bind(struct device_def* devdef,
struct device* pcidev_base
)
+vga_pci_bind(struct device_def* devdef,
morph_t* obj
)
{
{
- struct pci_
device* pcidev = PCI_DEVICE(pcidev_base)
;
+ struct pci_
probe* probe
;
- struct pci_base_addr* fb = &pcidev->bar[0];
- struct pci_base_addr* mmio = &pcidev->bar[2];
+ struct pci_base_addr* fb;
+ struct pci_base_addr* mmio;
+
+ probe = changeling_reveal(obj, pci_probe_morpher);
+ fb = &probe->bar[0];
+ mmio = &probe->bar[2];
if (PCI_BAR_ADDR_IO(mmio->type)) {
return EINVAL;
}
if (PCI_BAR_ADDR_IO(mmio->type)) {
return EINVAL;
}
- pci_reg_t cmd = pci_read_cspace(p
cidev
->cspace_base, PCI_REG_STATUS_CMD);
+ pci_reg_t cmd = pci_read_cspace(p
robe
->cspace_base, PCI_REG_STATUS_CMD);
cmd |= (PCI_RCMD_MM_ACCESS | PCI_RCMD_DISABLE_INTR | PCI_RCMD_BUS_MASTER);
cmd |= (PCI_RCMD_MM_ACCESS | PCI_RCMD_DISABLE_INTR | PCI_RCMD_BUS_MASTER);
- pci_write_cspace(p
cidev
->cspace_base, PCI_REG_STATUS_CMD, cmd);
+ pci_write_cspace(p
robe
->cspace_base, PCI_REG_STATUS_CMD, cmd);
ptr_t fb_mapped = ioremap(fb->start, FB256K);
ptr_t mmio_mapped = ioremap(mmio->start, mmio->size);
ptr_t fb_mapped = ioremap(fb->start, FB256K);
ptr_t mmio_mapped = ioremap(mmio->start, mmio->size);
@@
-96,27
+100,27
@@
vga_pci_bind(struct device_def* devdef, struct device* pcidev_base)
return 0;
}
return 0;
}
-static int
-vga_pci_init(struct device_def* def)
-{
- return pci_bind_definition_all(pcidev_def(def));
-}
+static bool
+vga_pci_compat(struct pci_probe* probe)
+{
#define VGA_PCI_CLASS 0x30000
#define VGA_PCI_CLASS 0x30000
+ return pci_device_class(probe) == VGA_PCI_CLASS;
+}
-static bool
-vga_pci_compat(struct pci_device_def* def,
- struct pci_device* pcidev)
+static int
+vga_pci_register(struct device_def* def)
{
{
- return
pci_device_class(pcidev) == VGA_PCI_CLASS
;
+ return
!pci_register_driver(def, vga_pci_compat)
;
}
}
+static struct device_def vga_pci_devdef = {
+ def_device_class(GENERIC, DISP, VGA),
+ def_device_name("Generic VGA"),
+
+ def_on_register(vga_pci_register),
+ def_on_create(vga_pci_bind),
-static struct pci_device_def vga_pci_devdef = {
- .devdef = { .class = DEVCLASS(DEVIF_PCI, DEVFN_DISP, DEV_VGA),
- .name = "Generic VGA",
- .init = vga_pci_init,
- .bind = vga_pci_bind },
- .test_compatibility = vga_pci_compat
+ def_non_trivial
};
};
-EXPORT_
PCI_
DEVICE(vga_pci, &vga_pci_devdef, load_onboot);
\ No newline at end of file
+EXPORT_DEVICE(vga_pci, &vga_pci_devdef, load_onboot);
\ No newline at end of file