Expand PMF_FN_* macros.
[netbsd-mini2440.git] / sys / dev / usb / umidi_quirks.h
blob452048760d8d2f9c9bbcc0c1c41d92d70d72f209
1 /* $NetBSD: umidi_quirks.h,v 1.7 2008/04/28 20:24:00 martin Exp $ */
3 /*
4 * Copyright (c) 2001 The NetBSD Foundation, Inc.
5 * All rights reserved.
7 * This code is derived from software contributed to The NetBSD Foundation
8 * by Takuya SHIOZAKI (tshiozak@NetBSD.org).
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted provided that the following conditions
12 * are met:
13 * 1. Redistributions of source code must retain the above copyright
14 * notice, this list of conditions and the following disclaimer.
15 * 2. Redistributions in binary form must reproduce the above copyright
16 * notice, this list of conditions and the following disclaimer in the
17 * documentation and/or other materials provided with the distribution.
19 * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 * POSSIBILITY OF SUCH DAMAGE.
34 * quirk code for UMIDI
37 #ifndef _DEV_USB_UMIDI_QUIRKS_H_
38 #define _DEV_USB_UMIDI_QUIRKS_H_
40 struct umq_data {
41 int type;
42 #define UMQ_TYPE_NONE 0
43 #define UMQ_TYPE_FIXED_EP 1
44 #define UMQ_TYPE_YAMAHA 2
45 #define UMQ_TYPE_MIDIMAN_GARBLE 3
46 #define UMQ_TYPE_CN_SEQ_PER_EP 4 /* should be default behavior, but isn't */
47 #define UMQ_TYPE_CN_SEQ_GLOBAL 5 /* shouldn't be default behavior, but is */
48 #define UMQ_TYPE_CN_FIXED 6 /* should be a joke, but isn't funny */
49 #define UMQ_TYPE_MD_FIXED 7 /* in case CN_FIXED gives a weird order */
50 const void *data;
53 struct umidi_quirk {
54 int vendor;
55 int product;
56 int iface;
57 const struct umq_data *quirks;
58 u_int32_t type_mask;
60 #define UMQ_ISTYPE(q, type) \
61 ((q)->sc_quirk && ((q)->sc_quirk->type_mask & (1<<((type)-1))))
63 #define UMQ_TERMINATOR { .type = UMQ_TYPE_NONE, },
64 #define UMQ_DEF(v, p, i) \
65 static const struct umq_data umq_##v##_##p##_##i[]
66 #define UMQ_REG(v, p, i) \
67 { USB_VENDOR_##v, USB_PRODUCT_##p, i, \
68 umq_##v##_##p##_##i, 0 }
69 #define ANYIFACE -1
70 #define ANYVENDOR -1
71 #define USB_VENDOR_ANYVENDOR ANYVENDOR
72 #define ANYPRODUCT -1
73 #define USB_PRODUCT_ANYPRODUCT ANYPRODUCT
76 * quirk - fixed port. By the way, the ep field contains not the
77 * endpoint address, but the index of the endpoint descriptor.
80 struct umq_fixed_ep_endpoint {
81 int ep;
82 int num_jacks;
84 struct umq_fixed_ep_desc {
85 int num_out_ep;
86 int num_in_ep;
87 const struct umq_fixed_ep_endpoint *out_ep;
88 const struct umq_fixed_ep_endpoint *in_ep;
91 #define UMQ_FIXED_EP_DATA_DEF(v, p, i, noep, niep) \
92 static const struct umq_fixed_ep_endpoint \
93 umq_##v##_##p##_##i##_fixed_ep_endpoints[noep+niep]
95 #define UMQ_FIXED_EP_DEF(v, p, i, noep, niep) \
96 static const struct umq_fixed_ep_desc \
97 umq_##v##_##p##_##i##_fixed_ep_desc = { \
98 noep, niep, \
99 &umq_##v##_##p##_##i##_fixed_ep_endpoints[0], \
100 &umq_##v##_##p##_##i##_fixed_ep_endpoints[noep], \
101 }; \
103 #define UMQ_FIXED_EP_REG(v, p, i) \
104 { UMQ_TYPE_FIXED_EP, &umq_##v##_##p##_##i##_fixed_ep_desc }
107 * quirk - fixed cable numbers. Supply as many values as there are jacks,
108 * in the same jack order implied by the FIXED_EP_DEF. Each value becomes
109 * the cable number of the corresponding jack.
111 #define UMQ_FIXED_CN_DEF(v, p, i) \
112 static const unsigned char umq_##v##_##p##_##i##_fixed_cn_desc[]
113 #define UMQ_FIXED_CN_REG(v, p, i) \
114 { UMQ_TYPE_CN_FIXED, &umq_##v##_##p##_##i##_fixed_cn_desc }
117 * quirk - fixed mididev assignment. Supply pairs of numbers out, in, as
118 * many pairs as mididevs (that is, max(num_out_jack,num_in_jack)). The
119 * pairs, in order, correspond to the mididevs that will be created; in
120 * each pair, out is the index of the out_jack to bind and in is the
121 * index of the in_jack, both in the order implied by the FIXED_EP_DEF.
122 * Either out or in can be -1 to bind no out jack or in jack, respectively,
123 * to the corresponding mididev.
125 #define UMQ_FIXED_MD_DEF(v, p, i) \
126 static const unsigned char umq_##v##_##p##_##i##_fixed_md_desc[]
127 #define UMQ_FIXED_MD_REG(v, p, i) \
128 { UMQ_TYPE_MD_FIXED, &umq_##v##_##p##_##i##_fixed_md_desc }
131 * generic boolean quirk, no data
133 #define UMQ_TYPE(t) \
134 { UMQ_TYPE_##t, NULL }
137 * quirk - yamaha style midi I/F
139 #define UMQ_YAMAHA_REG(v, p, i) \
140 UMQ_TYPE(YAMAHA)
143 /* extern const struct umidi_quirk umidi_quirklist[]; */
144 const struct umidi_quirk *umidi_search_quirk(int, int, int);
145 void umidi_print_quirk(const struct umidi_quirk *);
146 const void *umidi_get_quirk_data_from_type(const struct umidi_quirk *, u_int32_t);
148 #endif