Changeset 5759975a in mainline for uspace/drv/bus


Ignore:
Timestamp:
2013-09-11T17:55:18Z (12 years ago)
Author:
Jakub Jermar <jakub@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
f18d01b6
Parents:
4c9b28a (diff), 26bc0fd1 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the (diff) links above to see all the changes relative to each parent.
Message:

Merge PIO_WINDOW_DEV_IFACE support.

Location:
uspace/drv/bus
Files:
3 edited

Legend:

Unmodified
Added
Removed
  • uspace/drv/bus/isa/isa.c

    r4c9b28a r5759975a  
    6767
    6868#include <device/hw_res.h>
     69#include <device/pio_window.h>
    6970
    7071#include "i8237.h"
     
    7980        ddf_dev_t *dev;
    8081        ddf_fun_t *fctl;
     82        pio_window_t pio_win;
    8183        list_t functions;
    8284} isa_bus_t;
     
    405407        hw_resource_t *resources = fun->hw_resources.resources;
    406408
     409        isa_bus_t *isa = isa_bus(ddf_fun_get_dev(fun->fnode));
     410
    407411        if (count < ISA_MAX_HW_RES) {
    408412                resources[count].type = IO_RANGE;
    409413                resources[count].res.io_range.address = addr;
     414                resources[count].res.io_range.address += isa->pio_win.io.base;
    410415                resources[count].res.io_range.size = len;
    411416                resources[count].res.io_range.endianness = LITTLE_ENDIAN;
     
    604609static int isa_dev_add(ddf_dev_t *dev)
    605610{
     611        async_sess_t *sess;
     612        int rc;
     613
    606614        ddf_msg(LVL_DEBUG, "isa_dev_add, device handle = %d",
    607615            (int) ddf_dev_get_handle(dev));
     
    614622        isa->dev = dev;
    615623        list_initialize(&isa->functions);
     624
     625        sess = ddf_dev_parent_sess_create(dev, EXCHANGE_SERIALIZE);
     626        if (sess == NULL) {
     627                ddf_msg(LVL_ERROR, "isa_dev_add failed to connect to the "
     628                    "parent driver.");
     629                return ENOENT;
     630        }
     631
     632        rc = pio_window_get(sess, &isa->pio_win);
     633        if (rc != EOK) {
     634                ddf_msg(LVL_ERROR, "isa_dev_add failed to get PIO window "
     635                    "for the device.");
     636                return rc;
     637        }       
    616638
    617639        /* Make the bus device more visible. Does not do anything. */
  • uspace/drv/bus/pci/pciintel/pci.c

    r4c9b28a r5759975a  
    5757#include <ops/hw_res.h>
    5858#include <device/hw_res.h>
     59#include <ops/pio_window.h>
     60#include <device/pio_window.h>
    5961#include <ddi.h>
    6062#include <pci_dev_iface.h>
     
    141143}
    142144
     145static pio_window_t *pciintel_get_pio_window(ddf_fun_t *fnode)
     146{
     147        pci_fun_t *fun = pci_fun(fnode);
     148       
     149        if (fun == NULL)
     150                return NULL;
     151        return &fun->pio_window;
     152}
     153
     154
    143155static int pci_config_space_write_32(ddf_fun_t *fun, uint32_t address,
    144156    uint32_t data)
     
    198210        .get_resource_list = &pciintel_get_resources,
    199211        .enable_interrupt = &pciintel_enable_interrupt,
     212};
     213
     214static pio_window_ops_t pciintel_pio_window_ops = {
     215        .get_pio_window = &pciintel_get_pio_window
    200216};
    201217
     
    211227static ddf_dev_ops_t pci_fun_ops = {
    212228        .interfaces[HW_RES_DEV_IFACE] = &pciintel_hw_res_ops,
     229        .interfaces[PIO_WINDOW_DEV_IFACE] = &pciintel_pio_window_ops,
    213230        .interfaces[PCI_DEV_IFACE] = &pci_dev_ops
    214231};
     
    617634                        pci_read_bars(fun);
    618635                        pci_read_interrupt(fun);
     636
     637                        /* Propagate the PIO window to the function. */
     638                        fun->pio_window = bus->pio_win;
    619639                       
    620640                        ddf_fun_set_ops(fun->fnode, &pci_fun_ops);
     
    647667static int pci_dev_add(ddf_dev_t *dnode)
    648668{
     669        hw_resource_list_t hw_resources;
    649670        pci_bus_t *bus = NULL;
    650671        ddf_fun_t *ctl = NULL;
     
    672693                goto fail;
    673694        }
    674        
    675         hw_resource_list_t hw_resources;
     695
     696        rc = pio_window_get(sess, &bus->pio_win);
     697        if (rc != EOK) {
     698                ddf_msg(LVL_ERROR, "pci_dev_add failed to get PIO window "
     699                    "for the device.");
     700                goto fail;
     701        }
    676702       
    677703        rc = hw_res_get_resource_list(sess, &hw_resources);
     
    763789{
    764790        ddf_log_init(NAME);
    765         pci_fun_ops.interfaces[HW_RES_DEV_IFACE] = &pciintel_hw_res_ops;
    766         pci_fun_ops.interfaces[PCI_DEV_IFACE] = &pci_dev_ops;
    767791}
    768792
  • uspace/drv/bus/pci/pciintel/pci.h

    r4c9b28a r5759975a  
    4040#include "pci_regs.h"
    4141
    42 #define PCI_MAX_HW_RES 8
     42#define PCI_MAX_HW_RES 10
    4343
    4444typedef struct pciintel_bus {
     
    4949        void *conf_data_port;
    5050        void *conf_addr_port;
     51        pio_window_t pio_win;
    5152        fibril_mutex_t conf_mutex;
    5253} pci_bus_t;
     
    6869        hw_resource_list_t hw_resources;
    6970        hw_resource_t resources[PCI_MAX_HW_RES];
     71        pio_window_t pio_window;
    7072} pci_fun_t;
    7173
Note: See TracChangeset for help on using the changeset viewer.