source: svn/newcon3bcm2_21bu/nexus/modules/frontend/common/src/nexus_frontend_upstream.c

Last change on this file was 76, checked in by megakiss, 10 years ago

1W 대기전력을 만족시키기 위하여 POWEROFF시 튜너를 Standby 상태로 함

  • Property svn:executable set to *
File size: 5.1 KB
Line 
1/***************************************************************************
2*     (c)2004-2009 Broadcom Corporation
3
4*  This program is the proprietary software of Broadcom Corporation and/or its licensors,
5*  and may only be used, duplicated, modified or distributed pursuant to the terms and
6*  conditions of a separate, written license agreement executed between you and Broadcom
7*  (an "Authorized License").  Except as set forth in an Authorized License, Broadcom grants
8*  no license (express or implied), right to use, or waiver of any kind with respect to the
9*  Software, and Broadcom expressly reserves all rights in and to the Software and all
10*  intellectual property rights therein.  IF YOU HAVE NO AUTHORIZED LICENSE, THEN YOU
11*  HAVE NO RIGHT TO USE THIS SOFTWARE IN ANY WAY, AND SHOULD IMMEDIATELY
12*  NOTIFY BROADCOM AND DISCONTINUE ALL USE OF THE SOFTWARE. 
13*   
14*  Except as expressly set forth in the Authorized License,
15*   
16*  1.     This program, including its structure, sequence and organization, constitutes the valuable trade
17*  secrets of Broadcom, and you shall use all reasonable efforts to protect the confidentiality thereof,
18*  and to use this information only in connection with your use of Broadcom integrated circuit products.
19*   
20*  2.     TO THE MAXIMUM EXTENT PERMITTED BY LAW, THE SOFTWARE IS PROVIDED "AS IS"
21*  AND WITH ALL FAULTS AND BROADCOM MAKES NO PROMISES, REPRESENTATIONS OR
22*  WARRANTIES, EITHER EXPRESS, IMPLIED, STATUTORY, OR OTHERWISE, WITH RESPECT TO
23*  THE SOFTWARE.  BROADCOM SPECIFICALLY DISCLAIMS ANY AND ALL IMPLIED WARRANTIES
24*  OF TITLE, MERCHANTABILITY, NONINFRINGEMENT, FITNESS FOR A PARTICULAR PURPOSE,
25*  LACK OF VIRUSES, ACCURACY OR COMPLETENESS, QUIET ENJOYMENT, QUIET POSSESSION
26*  OR CORRESPONDENCE TO DESCRIPTION. YOU ASSUME THE ENTIRE RISK ARISING OUT OF
27*  USE OR PERFORMANCE OF THE SOFTWARE.
28
29*  3.     TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT SHALL BROADCOM OR ITS
30*  LICENSORS BE LIABLE FOR (i) CONSEQUENTIAL, INCIDENTAL, SPECIAL, INDIRECT, OR
31*  EXEMPLARY DAMAGES WHATSOEVER ARISING OUT OF OR IN ANY WAY RELATING TO YOUR
32*  USE OF OR INABILITY TO USE THE SOFTWARE EVEN IF BROADCOM HAS BEEN ADVISED OF
33*  THE POSSIBILITY OF SUCH DAMAGES; OR (ii) ANY AMOUNT IN EXCESS OF THE AMOUNT
34*  ACTUALLY PAID FOR THE SOFTWARE ITSELF OR U.S. $1, WHICHEVER IS GREATER. THESE
35*  LIMITATIONS SHALL APPLY NOTWITHSTANDING ANY FAILURE OF ESSENTIAL PURPOSE OF
36*  ANY LIMITED REMEDY.
37*
38* $brcm_Workfile: nexus_frontend_upstream.c $
39* $brcm_Revision: 2 $
40* $brcm_Date: 1/23/09 3:32p $
41*
42* API Description:
43*   API name: Frontend UpStream
44*    Generic APIs for upstream tuner device control
45*
46* Revision History:
47*
48* $brcm_Log: /nexus/modules/frontend/common/src/nexus_frontend_upstream.c $
49*
50* 2   1/23/09 3:32p jgarrett
51* PR 51457: Adding frontend extension hooks for tuners and
52*  frontends/demods
53*
54* 1   1/18/08 2:19p jgarrett
55* PR 38808: Merging to main branch
56*
57* Nexus_Devel/1   10/5/07 5:52p jgarrett
58* PR 35551: Adding initial version
59*
60***************************************************************************/
61
62#include "nexus_frontend_module.h"
63
64BDBG_MODULE(nexus_frontend_upstream.c);
65
66/***************************************************************************
67Summary:
68        Initialize an upstream settings structure to defaults
69See Also:
70    NEXUS_Frontend_TuneUpstream
71 ***************************************************************************/
72void NEXUS_Frontend_GetDefaultUpstreamSettings(
73    NEXUS_FrontendUpstreamSettings *pSettings
74    )
75{
76    BKNI_Memset(pSettings, 0, sizeof(*pSettings));
77}
78
79/***************************************************************************
80Summary:
81        Tune an upstream tuner
82See Also:
83    NEXUS_Frontend_InitUpstreamSettings
84 ***************************************************************************/
85NEXUS_Error NEXUS_Frontend_TuneUpstream(
86    NEXUS_FrontendHandle handle,
87    const NEXUS_FrontendUpstreamSettings *pSettings
88    )
89{
90    BDBG_ASSERT(NULL != handle);
91    BDBG_ASSERT(NULL != pSettings);
92
93    if ( NULL == handle->tuneUpstream )
94    {
95        if ( handle->pParentFrontend )
96        {
97            return NEXUS_Frontend_TuneUpstream(handle->pParentFrontend, pSettings);
98        }
99        else
100        {
101            return BERR_TRACE(BERR_NOT_SUPPORTED);
102        }
103    }
104    else
105    {
106        return handle->tuneUpstream(handle->pDeviceHandle, pSettings);
107    }
108}
109
110/***************************************************************************
111Summary:
112        Get the current status of an upstream tuner
113See Also:
114    NEXUS_Frontend_TuneUpstream
115 ***************************************************************************/
116NEXUS_Error NEXUS_Frontend_GetUpstreamStatus(
117    NEXUS_FrontendHandle handle,
118    NEXUS_FrontendUpstreamStatus *pStatus
119    )
120{
121    BDBG_ASSERT(NULL != handle);
122    BDBG_ASSERT(NULL != pStatus);
123
124    if ( NULL == handle->getUpstreamStatus )
125    {
126        if ( handle->pParentFrontend )
127        {
128            return NEXUS_Frontend_GetUpstreamStatus(handle->pParentFrontend, pStatus);
129        }
130        else
131        {
132            return BERR_TRACE(BERR_NOT_SUPPORTED);
133        }
134    }
135    else
136    {
137        return handle->getUpstreamStatus(handle->pDeviceHandle, pStatus);
138    }
139}
140
Note: See TracBrowser for help on using the repository browser.