| Index: arch/arm/mach-tegra/nv/nvrm/dispatch/nvrm_pinmux_dispatch.c
|
| diff --git a/arch/arm/mach-tegra/nv/nvrm/dispatch/nvrm_pinmux_dispatch.c b/arch/arm/mach-tegra/nv/nvrm/dispatch/nvrm_pinmux_dispatch.c
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..4064ca6e0029bac360a6ea359970f60a6a903163
|
| --- /dev/null
|
| +++ b/arch/arm/mach-tegra/nv/nvrm/dispatch/nvrm_pinmux_dispatch.c
|
| @@ -0,0 +1,301 @@
|
| +/*
|
| + * Copyright (c) 2009 NVIDIA Corporation.
|
| + * All rights reserved.
|
| + *
|
| + * Redistribution and use in source and binary forms, with or without
|
| + * modification, are permitted provided that the following conditions are met:
|
| + *
|
| + * Redistributions of source code must retain the above copyright notice,
|
| + * this list of conditions and the following disclaimer.
|
| + *
|
| + * Redistributions in binary form must reproduce the above copyright notice,
|
| + * this list of conditions and the following disclaimer in the documentation
|
| + * and/or other materials provided with the distribution.
|
| + *
|
| + * Neither the name of the NVIDIA Corporation nor the names of its contributors
|
| + * may be used to endorse or promote products derived from this software
|
| + * without specific prior written permission.
|
| + *
|
| + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
| + * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
| + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
| + * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
| + * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
| + * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
| + * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
| + * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
| + * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
| + * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
| + * POSSIBILITY OF SUCH DAMAGE.
|
| + *
|
| + */
|
| +
|
| +#define NV_IDL_IS_DISPATCH
|
| +
|
| +#include "nvcommon.h"
|
| +#include "nvos.h"
|
| +#include "nvassert.h"
|
| +#include "nvreftrack.h"
|
| +#include "nvidlcmd.h"
|
| +#include "nvrm_pinmux.h"
|
| +
|
| +#define OFFSET( s, e ) (NvU32)(void *)(&(((s*)0)->e))
|
| +
|
| +
|
| +typedef struct NvRmGetStraps_in_t
|
| +{
|
| + NvU32 package_;
|
| + NvU32 function_;
|
| + NvRmDeviceHandle hDevice;
|
| + NvRmStrapGroup StrapGroup;
|
| +} NV_ALIGN(4) NvRmGetStraps_in;
|
| +
|
| +typedef struct NvRmGetStraps_inout_t
|
| +{
|
| + NvU32 dummy_;
|
| +} NV_ALIGN(4) NvRmGetStraps_inout;
|
| +
|
| +typedef struct NvRmGetStraps_out_t
|
| +{
|
| + NvError ret_;
|
| + NvU32 pStrapValue;
|
| +} NV_ALIGN(4) NvRmGetStraps_out;
|
| +
|
| +typedef struct NvRmGetStraps_params_t
|
| +{
|
| + NvRmGetStraps_in in;
|
| + NvRmGetStraps_inout inout;
|
| + NvRmGetStraps_out out;
|
| +} NvRmGetStraps_params;
|
| +
|
| +typedef struct NvRmGetModuleInterfaceCapabilities_in_t
|
| +{
|
| + NvU32 package_;
|
| + NvU32 function_;
|
| + NvRmDeviceHandle hRm;
|
| + NvRmModuleID ModuleId;
|
| + NvU32 CapStructSize;
|
| + void* pCaps;
|
| +} NV_ALIGN(4) NvRmGetModuleInterfaceCapabilities_in;
|
| +
|
| +typedef struct NvRmGetModuleInterfaceCapabilities_inout_t
|
| +{
|
| + NvU32 dummy_;
|
| +} NV_ALIGN(4) NvRmGetModuleInterfaceCapabilities_inout;
|
| +
|
| +typedef struct NvRmGetModuleInterfaceCapabilities_out_t
|
| +{
|
| + NvError ret_;
|
| +} NV_ALIGN(4) NvRmGetModuleInterfaceCapabilities_out;
|
| +
|
| +typedef struct NvRmGetModuleInterfaceCapabilities_params_t
|
| +{
|
| + NvRmGetModuleInterfaceCapabilities_in in;
|
| + NvRmGetModuleInterfaceCapabilities_inout inout;
|
| + NvRmGetModuleInterfaceCapabilities_out out;
|
| +} NvRmGetModuleInterfaceCapabilities_params;
|
| +
|
| +typedef struct NvRmExternalClockConfig_in_t
|
| +{
|
| + NvU32 package_;
|
| + NvU32 function_;
|
| + NvRmDeviceHandle hDevice;
|
| + NvU32 IoModule;
|
| + NvU32 Instance;
|
| + NvU32 Config;
|
| + NvBool EnableTristate;
|
| +} NV_ALIGN(4) NvRmExternalClockConfig_in;
|
| +
|
| +typedef struct NvRmExternalClockConfig_inout_t
|
| +{
|
| + NvU32 dummy_;
|
| +} NV_ALIGN(4) NvRmExternalClockConfig_inout;
|
| +
|
| +typedef struct NvRmExternalClockConfig_out_t
|
| +{
|
| + NvU32 ret_;
|
| +} NV_ALIGN(4) NvRmExternalClockConfig_out;
|
| +
|
| +typedef struct NvRmExternalClockConfig_params_t
|
| +{
|
| + NvRmExternalClockConfig_in in;
|
| + NvRmExternalClockConfig_inout inout;
|
| + NvRmExternalClockConfig_out out;
|
| +} NvRmExternalClockConfig_params;
|
| +
|
| +typedef struct NvRmSetOdmModuleTristate_in_t
|
| +{
|
| + NvU32 package_;
|
| + NvU32 function_;
|
| + NvRmDeviceHandle hDevice;
|
| + NvU32 OdmModule;
|
| + NvU32 OdmInstance;
|
| + NvBool EnableTristate;
|
| +} NV_ALIGN(4) NvRmSetOdmModuleTristate_in;
|
| +
|
| +typedef struct NvRmSetOdmModuleTristate_inout_t
|
| +{
|
| + NvU32 dummy_;
|
| +} NV_ALIGN(4) NvRmSetOdmModuleTristate_inout;
|
| +
|
| +typedef struct NvRmSetOdmModuleTristate_out_t
|
| +{
|
| + NvError ret_;
|
| +} NV_ALIGN(4) NvRmSetOdmModuleTristate_out;
|
| +
|
| +typedef struct NvRmSetOdmModuleTristate_params_t
|
| +{
|
| + NvRmSetOdmModuleTristate_in in;
|
| + NvRmSetOdmModuleTristate_inout inout;
|
| + NvRmSetOdmModuleTristate_out out;
|
| +} NvRmSetOdmModuleTristate_params;
|
| +
|
| +typedef struct NvRmSetModuleTristate_in_t
|
| +{
|
| + NvU32 package_;
|
| + NvU32 function_;
|
| + NvRmDeviceHandle hDevice;
|
| + NvRmModuleID RmModule;
|
| + NvBool EnableTristate;
|
| +} NV_ALIGN(4) NvRmSetModuleTristate_in;
|
| +
|
| +typedef struct NvRmSetModuleTristate_inout_t
|
| +{
|
| + NvU32 dummy_;
|
| +} NV_ALIGN(4) NvRmSetModuleTristate_inout;
|
| +
|
| +typedef struct NvRmSetModuleTristate_out_t
|
| +{
|
| + NvError ret_;
|
| +} NV_ALIGN(4) NvRmSetModuleTristate_out;
|
| +
|
| +typedef struct NvRmSetModuleTristate_params_t
|
| +{
|
| + NvRmSetModuleTristate_in in;
|
| + NvRmSetModuleTristate_inout inout;
|
| + NvRmSetModuleTristate_out out;
|
| +} NvRmSetModuleTristate_params;
|
| +
|
| +static NvError NvRmGetStraps_dispatch_( void *InBuffer, NvU32 InSize, void *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
|
| +{
|
| + NvError err_ = NvSuccess;
|
| + NvRmGetStraps_in *p_in;
|
| + NvRmGetStraps_out *p_out;
|
| +
|
| + p_in = (NvRmGetStraps_in *)InBuffer;
|
| + p_out = (NvRmGetStraps_out *)((NvU8 *)OutBuffer + OFFSET(NvRmGetStraps_params, out) - OFFSET(NvRmGetStraps_params, inout));
|
| +
|
| +
|
| + p_out->ret_ = NvRmGetStraps( p_in->hDevice, p_in->StrapGroup, &p_out->pStrapValue );
|
| +
|
| + return err_;
|
| +}
|
| +
|
| +static NvError NvRmGetModuleInterfaceCapabilities_dispatch_( void *InBuffer, NvU32 InSize, void *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
|
| +{
|
| + NvError err_ = NvSuccess;
|
| + NvRmGetModuleInterfaceCapabilities_in *p_in;
|
| + NvRmGetModuleInterfaceCapabilities_out *p_out;
|
| + void* pCaps = NULL;
|
| +
|
| + p_in = (NvRmGetModuleInterfaceCapabilities_in *)InBuffer;
|
| + p_out = (NvRmGetModuleInterfaceCapabilities_out *)((NvU8 *)OutBuffer + OFFSET(NvRmGetModuleInterfaceCapabilities_params, out) - OFFSET(NvRmGetModuleInterfaceCapabilities_params, inout));
|
| +
|
| + if( p_in->CapStructSize && p_in->pCaps )
|
| + {
|
| + pCaps = (void* )NvOsAlloc( p_in->CapStructSize );
|
| + if( !pCaps )
|
| + {
|
| + err_ = NvError_InsufficientMemory;
|
| + goto clean;
|
| + }
|
| + }
|
| +
|
| + p_out->ret_ = NvRmGetModuleInterfaceCapabilities( p_in->hRm, p_in->ModuleId, p_in->CapStructSize, pCaps );
|
| +
|
| + if(p_in->pCaps && pCaps)
|
| + {
|
| + err_ = NvOsCopyOut( p_in->pCaps, pCaps, p_in->CapStructSize );
|
| + if( err_ != NvSuccess )
|
| + {
|
| + err_ = NvError_BadParameter;
|
| + }
|
| + }
|
| +clean:
|
| + NvOsFree( pCaps );
|
| + return err_;
|
| +}
|
| +
|
| +static NvError NvRmExternalClockConfig_dispatch_( void *InBuffer, NvU32 InSize, void *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
|
| +{
|
| + NvError err_ = NvSuccess;
|
| + NvRmExternalClockConfig_in *p_in;
|
| + NvRmExternalClockConfig_out *p_out;
|
| +
|
| + p_in = (NvRmExternalClockConfig_in *)InBuffer;
|
| + p_out = (NvRmExternalClockConfig_out *)((NvU8 *)OutBuffer + OFFSET(NvRmExternalClockConfig_params, out) - OFFSET(NvRmExternalClockConfig_params, inout));
|
| +
|
| +
|
| + p_out->ret_ = NvRmExternalClockConfig( p_in->hDevice, p_in->IoModule, p_in->Instance, p_in->Config, p_in->EnableTristate );
|
| +
|
| + return err_;
|
| +}
|
| +
|
| +static NvError NvRmSetOdmModuleTristate_dispatch_( void *InBuffer, NvU32 InSize, void *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
|
| +{
|
| + NvError err_ = NvSuccess;
|
| + NvRmSetOdmModuleTristate_in *p_in;
|
| + NvRmSetOdmModuleTristate_out *p_out;
|
| +
|
| + p_in = (NvRmSetOdmModuleTristate_in *)InBuffer;
|
| + p_out = (NvRmSetOdmModuleTristate_out *)((NvU8 *)OutBuffer + OFFSET(NvRmSetOdmModuleTristate_params, out) - OFFSET(NvRmSetOdmModuleTristate_params, inout));
|
| +
|
| +
|
| + p_out->ret_ = NvRmSetOdmModuleTristate( p_in->hDevice, p_in->OdmModule, p_in->OdmInstance, p_in->EnableTristate );
|
| +
|
| + return err_;
|
| +}
|
| +
|
| +static NvError NvRmSetModuleTristate_dispatch_( void *InBuffer, NvU32 InSize, void *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
|
| +{
|
| + NvError err_ = NvSuccess;
|
| + NvRmSetModuleTristate_in *p_in;
|
| + NvRmSetModuleTristate_out *p_out;
|
| +
|
| + p_in = (NvRmSetModuleTristate_in *)InBuffer;
|
| + p_out = (NvRmSetModuleTristate_out *)((NvU8 *)OutBuffer + OFFSET(NvRmSetModuleTristate_params, out) - OFFSET(NvRmSetModuleTristate_params, inout));
|
| +
|
| +
|
| + p_out->ret_ = NvRmSetModuleTristate( p_in->hDevice, p_in->RmModule, p_in->EnableTristate );
|
| +
|
| + return err_;
|
| +}
|
| +
|
| +NvError nvrm_pinmux_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx );
|
| +NvError nvrm_pinmux_Dispatch( NvU32 function, void *InBuffer, NvU32 InSize, void *OutBuffer, NvU32 OutSize, NvDispatchCtx* Ctx )
|
| +{
|
| + NvError err_ = NvSuccess;
|
| +
|
| + switch( function ) {
|
| + case 4:
|
| + err_ = NvRmGetStraps_dispatch_( InBuffer, InSize, OutBuffer, OutSize, Ctx );
|
| + break;
|
| + case 3:
|
| + err_ = NvRmGetModuleInterfaceCapabilities_dispatch_( InBuffer, InSize, OutBuffer, OutSize, Ctx );
|
| + break;
|
| + case 2:
|
| + err_ = NvRmExternalClockConfig_dispatch_( InBuffer, InSize, OutBuffer, OutSize, Ctx );
|
| + break;
|
| + case 1:
|
| + err_ = NvRmSetOdmModuleTristate_dispatch_( InBuffer, InSize, OutBuffer, OutSize, Ctx );
|
| + break;
|
| + case 0:
|
| + err_ = NvRmSetModuleTristate_dispatch_( InBuffer, InSize, OutBuffer, OutSize, Ctx );
|
| + break;
|
| + default:
|
| + err_ = NvError_BadParameter;
|
| + break;
|
| + }
|
| +
|
| + return err_;
|
| +}
|
|
|