docs/how-to-build.md: use proper markup for directory names
[unleashed/tickless.git] / include / sys / ddimapreq.h
blob0237e0620cedca5341d39a8083add0afb4f6567a
1 /*
2 * CDDL HEADER START
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License, Version 1.0 only
6 * (the "License"). You may not use this file except in compliance
7 * with the License.
9 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10 * or http://www.opensolaris.org/os/licensing.
11 * See the License for the specific language governing permissions
12 * and limitations under the License.
14 * When distributing Covered Code, include this CDDL HEADER in each
15 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16 * If applicable, add the following below this CDDL HEADER, with the
17 * fields enclosed by brackets "[]" replaced with your own identifying
18 * information: Portions Copyright [yyyy] [name of copyright owner]
20 * CDDL HEADER END
23 * Copyright (c) 1991-1994 Sun Microsystems, Inc.
26 #ifndef _SYS_DDIMAPREQ_H
27 #define _SYS_DDIMAPREQ_H
29 #include <sys/mman.h>
30 #include <sys/dditypes.h>
32 #ifdef __cplusplus
33 extern "C" {
34 #endif
36 #ifdef _KERNEL
39 * Mapping requests are for an rnumber or for a regspec.
41 * A regspec is a generic triple, usually representing
42 * type, offset, length
44 * And is interpreted privately between the child and parent.
45 * The triple should be sufficient for representing byte addressable devices.
48 typedef union {
49 int rnumber;
50 struct regspec *rp;
51 } ddi_map_obj_t;
53 typedef enum {
54 DDI_MT_RNUMBER = 0,
55 DDI_MT_REGSPEC
56 } ddi_map_type_t;
59 * Mapping operators:
61 typedef enum {
62 DDI_MO_MAP_UNLOCKED = 0, /* Create mapping, do not lock down */
63 DDI_MO_MAP_LOCKED, /* Create locked down mapping */
64 DDI_MO_MAP_HANDLE, /* Create handle, do not map */
65 DDI_MO_UNMAP, /* Unmap (implies unlock, if locked) */
66 DDI_MO_UNLOCK /* Unlock mapping, do *not* unmap */
67 } ddi_map_op_t;
70 * Mapping request structure...
73 typedef struct {
74 ddi_map_op_t map_op;
75 ddi_map_type_t map_type;
76 ddi_map_obj_t map_obj;
77 int map_flags; /* See below... */
78 int map_prot; /* Prot bits (see sys/mman.h) */
79 ddi_acc_hdl_t *map_handlep;
80 int map_vers;
81 } ddi_map_req_t;
84 * version number
86 #define DDI_MAP_VERSION 0x0001
89 * Mappings subject to the following flags:
93 * Make mapping suitable for user program use.
95 #define DDI_MF_USER_MAPPING 0x1
98 * Make mapping suitable for kernel mapping.
100 #define DDI_MF_KERNEL_MAPPING 0x2
101 #define DDI_MF_DEVICE_MAPPING 0x4
103 #endif /* _KERNEL */
106 * Error (non-zero) return codes from DDI mapping functions...
109 #define DDI_ME_GENERIC (-1) /* Generic un-enumerated error */
110 #define DDI_ME_UNIMPLEMENTED (-2) /* Unimplemented operator */
111 #define DDI_ME_NORESOURCES (-3) /* No resources, try later? */
112 #define DDI_ME_UNSUPPORTED (-4) /* Op is not supported in impl. */
113 #define DDI_ME_REGSPEC_RANGE (-5) /* Addressing range error */
114 #define DDI_ME_RNUMBER_RANGE (-6) /* Addressing range error */
115 #define DDI_ME_INVAL (-7) /* Invalid input parameter */
117 #ifdef __cplusplus
119 #endif
121 #endif /* _SYS_DDIMAPREQ_H */