blob: f64b078196dabb3ca58cd37b2647c976460e9f12 [file] [log] [blame]
rjw6c1fd8f2022-11-30 14:33:01 +08001/*****************************************************************************
2* Copyright Statement:
3* --------------------
4* This software is protected by Copyright and the information contained
5* herein is confidential. The software may not be copied and the information
6* contained herein may not be used or disclosed except with the written
7* permission of MediaTek Inc. (C) 2012
8*
9* BY OPENING THIS FILE, BUYER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
10* THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
11* RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO BUYER ON
12* AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
13* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
14* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
15* NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
16* SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
17* SUPPLIED WITH THE MEDIATEK SOFTWARE, AND BUYER AGREES TO LOOK ONLY TO SUCH
18* THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. MEDIATEK SHALL ALSO
19* NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE RELEASES MADE TO BUYER'S
20* SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM.
21*
22* BUYER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND CUMULATIVE
23* LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
24* AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
25* OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY BUYER TO
26* MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE.
27*
28* THE TRANSACTION CONTEMPLATED HEREUNDER SHALL BE CONSTRUED IN ACCORDANCE
29* WITH THE LAWS OF THE STATE OF CALIFORNIA, USA, EXCLUDING ITS CONFLICT OF
30* LAWS PRINCIPLES. ANY DISPUTES, CONTROVERSIES OR CLAIMS ARISING THEREOF AND
31* RELATED THERETO SHALL BE SETTLED BY ARBITRATION IN SAN FRANCISCO, CA, UNDER
32* THE RULES OF THE INTERNATIONAL CHAMBER OF COMMERCE (ICC).
33*
34*****************************************************************************/
35
36/*******************************************************************************
37 * Filename:
38 * ---------
39 * asn1lib.h
40 *
41 * Project:
42 * --------
43 * MAUI
44 *
45 * Description:
46 * ------------
47 *
48 *
49 * Author:
50 * -------
51 *
52 *
53 *==============================================================================
54 * HISTORY
55 * Below this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
56 *------------------------------------------------------------------------------
57 *
58 *------------------------------------------------------------------------------
59 * Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
60 *==============================================================================
61 *******************************************************************************/
62
63#ifndef _ASN1LIB_h_
64#define _ASN1LIB_h_
65
66#include "kal_general_types.h"
67
68typedef enum asn_error_type {
69 NOT_ERROR,
70 RECOVERABLE_ERROR,
71 UNRECOVERABLE_ERROR
72} asn_error_type;
73
74typedef enum asn_error_detail {
75 SPARE_ERROR,
76 OUT_OF_RANGE_ERROR,
77 IGNORE_FUNCTION
78} asn_error_detail;
79
80typedef struct asn_cond_error_info {
81 kal_int32 cond_code;
82 void *ptr;
83} asn_cond_error_info;
84
85typedef struct asn_list_node
86{
87 struct asn_list_node *prev;
88 struct asn_list_node *next;
89 void *data;
90} asn_list_node;
91
92typedef struct asn_list
93{
94 asn_list_node *first;
95 asn_list_node *last;
96 asn_list_node *curr;
97 int count;
98 int dataSize;
99} asn_list;
100
101typedef struct ErrorStruct {
102 asn_error_type error_type;
103 asn_error_detail error_flag;
104 kal_int32 structNameEnum;
105 asn_list cond_errors;
106 kal_int32 comp_req;
107} ErrorStruct;
108
109struct prtBuffMgr{
110 char *buff;
111 int currbuff_size;
112 int origbuff_size;
113 int index;
114};
115
116typedef struct prtBuffMgr PrintBuffMgr;
117
118
119extern void asn_list_init(asn_list *list, kal_int32 dataSize);
120extern void InitErrorStruct(ErrorStruct *error_info);
121
122
123#endif /* _ASN1LIB_h_ */
124
125