source: mainline/uspace/lib/drv/include/ddf/driver.h@ 832cbe7

Last change on this file since 832cbe7 was 832cbe7, checked in by Jiri Svoboda <jiri@…>, 5 months ago

Add proper IDE PCI to ISA fallback mechanism.

To determine if legacy IDE I/O ports are free, isa-ide asks isa,
who asks pciintel. pciintel waits for bus enumeration to complete,
then waits for all functions except the one who is asking
(which is ISA bus) to stabilize. During attach pci-ide will claim
the legacy IDE ports. Thus, if at this point legacy IDE ports
are unclaimed, pciintel tells ISA they are free, which tells isa-ide,
which continues to attach. If they are not free, isa-ide will not
attach.

This works for all use cases, including system without PCI bus,
system with PCI bus, but no (or disabled) PCI IDE, system with PCI
IDE with unrecognized VID/PID (which we will handle in legacy ISA mode).

  • Property mode set to 100644
File size: 4.4 KB
Line 
1/*
2 * Copyright (c) 2025 Jiri Svoboda
3 * Copyright (c) 2010 Lenka Trochtova
4 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:
9 *
10 * - Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * - Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 * - The name of the author may not be used to endorse or promote products
16 * derived from this software without specific prior written permission.
17 *
18 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
27 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 */
29
30/** @addtogroup libdrv
31 * @{
32 */
33/** @file
34 */
35
36#ifndef DDF_DRIVER_H_
37#define DDF_DRIVER_H_
38
39#include <async.h>
40#include <ipc/devman.h>
41#include <ipc/dev_iface.h>
42#include "../dev_iface.h"
43
44/*
45 * Device
46 */
47
48typedef struct ddf_dev ddf_dev_t;
49typedef struct ddf_fun ddf_fun_t;
50
51/** Devices operations */
52typedef struct ddf_dev_ops {
53 /**
54 * Optional callback function called when a client is connecting to the
55 * device.
56 */
57 errno_t (*open)(ddf_fun_t *);
58
59 /**
60 * Optional callback function called when a client is disconnecting from
61 * the device.
62 */
63 void (*close)(ddf_fun_t *);
64
65 /** The table of standard interfaces implemented by the device. */
66 void *interfaces[DEV_IFACE_COUNT];
67
68 /**
69 * The default handler of remote client requests. If the client's remote
70 * request cannot be handled by any of the standard interfaces, the
71 * default handler is used.
72 */
73 remote_handler_t *default_handler;
74} ddf_dev_ops_t;
75
76/** Device structure */
77struct ddf_dev;
78
79/** Function structure */
80struct ddf_fun;
81
82/*
83 * Driver
84 */
85
86/** Generic device driver operations */
87typedef struct driver_ops {
88 /** Callback method for passing a new device to the device driver */
89 errno_t (*dev_add)(ddf_dev_t *);
90
91 /** Ask driver to remove a device */
92 errno_t (*dev_remove)(ddf_dev_t *);
93
94 /** Inform driver a device disappeared */
95 errno_t (*dev_gone)(ddf_dev_t *);
96
97 /** Ask driver to online a specific function */
98 errno_t (*fun_online)(ddf_fun_t *);
99
100 /** Ask driver to offline a specific function */
101 errno_t (*fun_offline)(ddf_fun_t *);
102} driver_ops_t;
103
104/** Driver structure */
105typedef struct driver {
106 /** Name of the device driver */
107 const char *name;
108 /** Generic device driver operations */
109 const driver_ops_t *driver_ops;
110} driver_t;
111
112extern int ddf_driver_main(const driver_t *);
113
114extern void *ddf_dev_data_alloc(ddf_dev_t *, size_t);
115extern void *ddf_dev_data_get(ddf_dev_t *);
116extern devman_handle_t ddf_dev_get_handle(ddf_dev_t *);
117extern const char *ddf_dev_get_name(ddf_dev_t *);
118extern async_sess_t *ddf_dev_parent_sess_get(ddf_dev_t *);
119extern ddf_fun_t *ddf_fun_create(ddf_dev_t *, fun_type_t, const char *);
120extern devman_handle_t ddf_fun_get_handle(ddf_fun_t *);
121extern void ddf_fun_destroy(ddf_fun_t *);
122extern void *ddf_fun_data_alloc(ddf_fun_t *, size_t);
123extern void *ddf_fun_data_get(ddf_fun_t *);
124extern const char *ddf_fun_get_name(ddf_fun_t *);
125extern errno_t ddf_fun_set_name(ddf_fun_t *, const char *);
126extern ddf_dev_t *ddf_fun_get_dev(ddf_fun_t *);
127extern errno_t ddf_fun_bind(ddf_fun_t *);
128extern errno_t ddf_fun_unbind(ddf_fun_t *);
129extern errno_t ddf_fun_online(ddf_fun_t *);
130extern errno_t ddf_fun_offline(ddf_fun_t *);
131extern errno_t ddf_fun_add_match_id(ddf_fun_t *, const char *, int);
132extern void ddf_fun_set_ops(ddf_fun_t *, const ddf_dev_ops_t *);
133extern void ddf_fun_set_conn_handler(ddf_fun_t *, async_port_handler_t);
134extern errno_t ddf_fun_add_to_category(ddf_fun_t *, const char *);
135extern errno_t ddf_fun_wait_stable(ddf_fun_t *);
136
137#endif
138
139/**
140 * @}
141 */
Note: See TracBrowser for help on using the repository browser.