OLD | NEW |
(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 |
OLD | NEW |