Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(271)

Side by Side Diff: arch/arm/mach-tegra/nv/nvrm/dispatch/NvRm_Dispatch.c

Issue 3256004: [ARM] tegra: add nvos/nvrm/nvmap drivers (Closed) Base URL: ssh://git@gitrw.chromium.org/kernel.git
Patch Set: remove ap15 headers Created 10 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 /*
2 * Copyright (c) 2009-2010 NVIDIA Corporation.
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions are met:
7 *
8 * Redistributions of source code must retain the above copyright notice,
9 * this list of conditions and the following disclaimer.
10 *
11 * Redistributions in binary form must reproduce the above copyright notice,
12 * this list of conditions and the following disclaimer in the documentation
13 * and/or other materials provided with the distribution.
14 *
15 * Neither the name of the NVIDIA Corporation nor the names of its contributors
16 * may be used to endorse or promote products derived from this software
17 * without specific prior written permission.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
20 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
23 * 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.
30 *
31 */
32
33 #include <linux/kernel.h>
34
35 #include "nvcommon.h"
36 #include "nvos.h"
37 #include "nvassert.h"
38 #include "nvidlcmd.h"
39 #include "nvreftrack.h"
40 #include "nvrm_xpc.h"
41 #include "nvrm_transport.h"
42 #include "nvrm_memctrl.h"
43 #include "nvrm_pcie.h"
44 #include "nvrm_pwm.h"
45 #include "nvrm_keylist.h"
46 #include "nvrm_pmu.h"
47 #include "nvrm_diag.h"
48 #include "nvrm_pinmux.h"
49 #include "nvrm_analog.h"
50 #include "nvrm_owr.h"
51 #include "nvrm_i2c.h"
52 #include "nvrm_spi.h"
53 #include "nvrm_interrupt.h"
54 #include "nvrm_dma.h"
55 #include "nvrm_power.h"
56 #include "nvrm_gpio.h"
57 #include "nvrm_module.h"
58 #include "nvrm_memmgr.h"
59 #include "nvrm_init.h"
60 NvError nvrm_xpc_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *O utBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
61 NvError nvrm_transport_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, v oid *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
62 NvError nvrm_memctrl_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, voi d *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
63 NvError nvrm_pcie_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void * OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
64 NvError nvrm_pwm_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *O utBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
65 NvError nvrm_keylist_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, voi d *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
66 NvError nvrm_pmu_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *O utBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
67 NvError nvrm_diag_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void * OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
68 NvError nvrm_pinmux_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
69 NvError nvrm_analog_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
70 NvError nvrm_owr_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *O utBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
71 NvError nvrm_i2c_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *O utBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
72 NvError nvrm_spi_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *O utBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
73 NvError nvrm_interrupt_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, v oid *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
74 NvError nvrm_dma_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *O utBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
75 NvError nvrm_power_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
76 NvError nvrm_gpio_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void * OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
77 NvError nvrm_module_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
78 NvError nvrm_memmgr_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
79 NvError nvrm_init_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void * OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
80
81 NvError nvrm_xpc_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *O utBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
82 {
83 printk("NVRM: %s %d\n", __func__, function);
84 return NvSuccess;
85 }
86
87 NvError nvrm_transport_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, v oid *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
88 {
89 printk("NVRM: %s %d\n", __func__, function);
90 return NvSuccess;
91 }
92
93 NvError nvrm_memctrl_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, voi d *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
94 {
95 printk("NVRM: %s %d\n", __func__, function);
96 return NvSuccess;
97 }
98
99 NvError nvrm_pcie_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void * OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
100 {
101 printk("NVRM: %s %d\n", __func__, function);
102 return NvSuccess;
103 }
104
105 NvError nvrm_pwm_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *O utBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
106 {
107 printk("NVRM: %s %d\n", __func__, function);
108 return NvSuccess;
109 }
110
111 NvError nvrm_keylist_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, voi d *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
112 {
113 printk("NVRM: %s %d\n", __func__, function);
114 return NvSuccess;
115 }
116
117 NvError nvrm_pmu_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *O utBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
118 {
119 printk("NVRM: %s %d\n", __func__, function);
120 return NvSuccess;
121 }
122
123 NvError nvrm_diag_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void * OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
124 {
125 printk("NVRM: %s %d\n", __func__, function);
126 return NvSuccess;
127 }
128
129 NvError nvrm_pinmux_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
130 {
131 printk("NVRM: %s %d\n", __func__, function);
132 return NvSuccess;
133 }
134
135 NvError nvrm_analog_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
136 {
137 printk("NVRM: %s %d\n", __func__, function);
138 return NvSuccess;
139 }
140
141 NvError nvrm_owr_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *O utBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
142 {
143 printk("NVRM: %s %d\n", __func__, function);
144 return NvSuccess;
145 }
146
147 NvError nvrm_i2c_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *O utBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
148 {
149 printk("NVRM: %s %d\n", __func__, function);
150 return NvSuccess;
151 }
152
153 NvError nvrm_spi_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *O utBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
154 {
155 printk("NVRM: %s %d\n", __func__, function);
156 return NvSuccess;
157 }
158
159 NvError nvrm_interrupt_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, v oid *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
160 {
161 printk("NVRM: %s %d\n", __func__, function);
162 return NvSuccess;
163 }
164
165 NvError nvrm_dma_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *O utBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
166 {
167 printk("NVRM: %s %d\n", __func__, function);
168 return NvSuccess;
169 }
170
171 NvError nvrm_power_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
172 {
173 printk("NVRM: %s %d\n", __func__, function);
174 return NvSuccess;
175 }
176
177 NvError nvrm_gpio_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void * OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
178 {
179 printk("NVRM: %s %d\n", __func__, function);
180 return NvSuccess;
181 }
182
183 NvError nvrm_module_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
184 {
185 printk("NVRM: %s %d\n", __func__, function);
186 return NvSuccess;
187 }
188
189 NvError nvrm_memmgr_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
190 {
191 printk("NVRM: %s %d\n", __func__, function);
192 return NvSuccess;
193 }
194
195 NvError nvrm_init_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void * OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
196 {
197 printk("NVRM: %s %d\n", __func__, function);
198 return NvSuccess;
199 }
200
201 // NvRm Package
202 typedef enum
203 {
204 NvRm_Invalid = 0,
205 NvRm_nvrm_xpc,
206 NvRm_nvrm_transport,
207 NvRm_nvrm_memctrl,
208 NvRm_nvrm_pcie,
209 NvRm_nvrm_pwm,
210 NvRm_nvrm_keylist,
211 NvRm_nvrm_pmu,
212 NvRm_nvrm_diag,
213 NvRm_nvrm_pinmux,
214 NvRm_nvrm_analog,
215 NvRm_nvrm_owr,
216 NvRm_nvrm_i2c,
217 NvRm_nvrm_spi,
218 NvRm_nvrm_interrupt,
219 NvRm_nvrm_dma,
220 NvRm_nvrm_power,
221 NvRm_nvrm_gpio,
222 NvRm_nvrm_module,
223 NvRm_nvrm_memmgr,
224 NvRm_nvrm_init,
225 NvRm_Num,
226 NvRm_Force32 = 0x7FFFFFFF,
227 } NvRm;
228
229 typedef NvError (* NvIdlDispatchFunc)( NvU32 function, void *InBuffer, NvU32 InS ize, void *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
230
231 typedef struct NvIdlDispatchTableRec
232 {
233 NvU32 PackageId;
234 NvIdlDispatchFunc DispFunc;
235 } NvIdlDispatchTable;
236
237 static NvIdlDispatchTable gs_DispatchTable[] =
238 {
239 { NvRm_nvrm_xpc, nvrm_xpc_Dispatch },
240 { NvRm_nvrm_transport, nvrm_transport_Dispatch },
241 { NvRm_nvrm_memctrl, nvrm_memctrl_Dispatch },
242 { NvRm_nvrm_pcie, nvrm_pcie_Dispatch },
243 { NvRm_nvrm_pwm, nvrm_pwm_Dispatch },
244 { NvRm_nvrm_keylist, nvrm_keylist_Dispatch },
245 { NvRm_nvrm_pmu, nvrm_pmu_Dispatch },
246 { NvRm_nvrm_diag, nvrm_diag_Dispatch },
247 { NvRm_nvrm_pinmux, nvrm_pinmux_Dispatch },
248 { NvRm_nvrm_analog, nvrm_analog_Dispatch },
249 { NvRm_nvrm_owr, nvrm_owr_Dispatch },
250 { NvRm_nvrm_i2c, nvrm_i2c_Dispatch },
251 { NvRm_nvrm_spi, nvrm_spi_Dispatch },
252 { NvRm_nvrm_interrupt, nvrm_interrupt_Dispatch },
253 { NvRm_nvrm_dma, nvrm_dma_Dispatch },
254 { NvRm_nvrm_power, nvrm_power_Dispatch },
255 { NvRm_nvrm_gpio, nvrm_gpio_Dispatch },
256 { NvRm_nvrm_module, nvrm_module_Dispatch },
257 { NvRm_nvrm_memmgr, nvrm_memmgr_Dispatch },
258 { NvRm_nvrm_init, nvrm_init_Dispatch },
259 { 0 },
260 };
261
262 NvError NvRm_Dispatch( void *InBuffer, NvU32 InSize, void *OutBuffer, NvU32 OutS ize, NvDispatchCtx* Ctx )
263 {
264 NvU32 packid_;
265 NvU32 funcid_;
266 NvIdlDispatchTable *table_;
267
268 NV_ASSERT( InBuffer );
269 NV_ASSERT( OutBuffer );
270
271 packid_ = ((NvU32 *)InBuffer)[0];
272 funcid_ = ((NvU32 *)InBuffer)[1];
273 table_ = gs_DispatchTable;
274
275 if ( packid_-1 >= NV_ARRAY_SIZE(gs_DispatchTable) ||
276 !table_[packid_ - 1].DispFunc )
277 return NvError_IoctlFailed;
278
279 return table_[packid_ - 1].DispFunc( funcid_, InBuffer, InSize,
280 OutBuffer, OutSize, Ctx );
281 }
282
OLDNEW
« no previous file with comments | « arch/arm/mach-tegra/nv/nvrm/dispatch/Makefile ('k') | arch/arm/mach-tegra/nv/nvrm/dispatch/nvrm_analog_dispatch.c » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698