blob: d6df82d082dceeb6319fe6b4b2df6f8ee5297ae9 [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) 2005
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 *
38 * Filename:
39 * ---------
40 * NAND_DAL.H
41 *
42 * Project:
43 * --------
44 * MOLY
45 *
46 * Description:
47 * ------------
48 * This is a NAND Flash Device Abstraction Layer file.
49 *
50 * Author:
51 * -------
52 * -------
53 *
54 *==============================================================================
55 * HISTORY
56 * Below this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
57 *------------------------------------------------------------------------------
58 * removed!
59 * removed!
60 * removed!
61 *
62 * removed!
63 * removed!
64 * removed!
65 *
66 * removed!
67 * removed!
68 * removed!
69 *
70 *
71 *------------------------------------------------------------------------------
72 * Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
73 *==============================================================================
74 *******************************************************************************/
75#ifndef NAND_DAL_H
76#define NAND_DAL_H
77
78/****************************
79 * Include Header Files *
80 ****************************/
81#if defined(__DOWNLOAD_AGENT__)
82#include "NAND_DA_internal.h"
83#include "NAND_DAL_internal.h"
84#endif
85#include "fota_error.h"
86// Add for RHR
87// RHR Remove #include "kal_non_specific_general_types.h"
88#include "kal_general_types.h"
89// Add for RHR
90/*******************************************************************************
91 * Operation error code for NFB functions
92 *******************************************************************************/
93#define ERROR_NFB_SUCCESS (ERROR_FOTA_SUCCESS)
94#define ERROR_NFB_READ (ERROR_FOTA_READ)
95#define ERROR_NFB_PROGRAM (ERROR_FOTA_PROGRAM)
96#define ERROR_NFB_ERASE (ERROR_FOTA_ERASE)
97#define ERROR_NFB_BAD_BLOCK (ERROR_FOTA_BAD_BLOCK)
98#define ERROR_NFB_CHECKSUM (ERROR_FOTA_NFB_CHECKSUM)
99#define ERROR_NFB_ECC_CORRECTED (ERROR_FOTA_ECC_CORRECTED)
100#define ERROR_NFB_INVALID_PARAMETER (ERROR_FOTA_INVALID_PARAMETER)
101#define ERROR_NFB_NOT_INITIALIZED (ERROR_FOTA_NOT_INITIALIZED)
102#define ERROR_NFB_CUSTOMIZATION (ERROR_FOTA_CUSTOMIZATION)
103#define ERROR_NFB_MASK (0x80000000)
104
105/**************************************
106 * Returns: FS_NO_ERROR
107 * FS_NAND_DEVICE_NOT_SUPPORTED
108 * FS_FLASH_MOUNT_ERROR
109 *************************************/
110kal_int32 DAL_init (void);
111kal_uint32 DAL_GetBlockSize(void);
112kal_uint32 DAL_GetPageSize(void);
113kal_bool NANDsanitycheck_Factory(void);
114
115typedef enum
116{
117 NFB_READ_PAGE_ONLY_WITH_ECC = 0,
118 NFB_READ_PAGE_ONLY_WITHOUT_ECC,
119 NFB_READ_SPARE_ONLY_WITHOUT_ECC,
120 NFB_READ_PAGE_SPARE_WITHOUT_ECC,
121 NFB_READ_PAGE_FLAG_END
122}NFB_ReadPage_t;
123
124#ifdef _NAND_FLASH_BOOTING_
125
126int NFB_ProgramPhysicalPage(kal_uint32 PhyBlock, kal_uint32 PhyPage, void * Data, kal_bool DALRemap);
127
128int NFB_ProgramPhysicalSpare(kal_uint32 PhyBlock, kal_uint32 PhyPage, void * Data, kal_bool chksum, kal_bool DALRemap);
129
130int NFB_ErasePhysicalBlock(kal_uint32 PhyBlock, kal_bool DALRemap);
131
132int NFB_MarkBadBlock(kal_uint32 PhyBlock, kal_bool DALRemap);
133
134int NFB_ProgramPhysicalPageWithSpare(kal_uint32 PhyBlock, kal_uint32 PhyPage, void *Data, void *Spare, kal_bool DALRemap);
135
136kal_int32 NFB_ReadPhysicalPage(kal_uint32 PhyBlock, kal_uint32 PhyPage, void * Data);
137
138int NFB_ReadPhysicalSpare(kal_uint32 PhyBlock, kal_uint32 PhyPage, void * Data, kal_bool chksum);
139
140#if defined(__DOWNLOAD_AGENT__)
141int NFB_ForceEraseBlock(kal_uint32 PhyBlock, kal_bool DALRemap);
142kal_int32 NFB_ReadPhysicalPageSpareECC(kal_uint32 PhyBlock, kal_uint32 PhyPage, void * Data, void *Spare, NFB_ReadPage_t flag);
143kal_int32 NFB_GetFlashInfo(NFB_FLASH_INFO* flash_info_p);
144kal_uint32 NFB_HB_init(void * BufferPtr, kal_uint32 Length, kal_bool Scramble);
145kal_uint32 NFB_HB_QueryBlock(kal_uint32 Block, kal_uint32 QueryType);
146kal_uint32 NFB_HB_UpdateBadBlock(kal_uint32 phyBlock);
147kal_uint32 NFB_HB_WriteBack();
148#endif
149
150#if defined(__UBL__)
151kal_int32 NFB_SyncFlashInfo(void* flash_info_p, kal_uint32 len);
152#endif
153
154#if defined(__FOTA_DM__)
155kal_int32 NFB_ReadPhysicalPageWithSpare(kal_uint32 PhyBlock, kal_uint32 PhyPage, kal_uint8* Data);
156#endif // defined(__FOTA_DM__)
157
158kal_int32 NFB_CheckGoodBlock(kal_uint32 Block);
159
160kal_int32 NFB_CheckGoodBlock2(kal_uint32 Block, kal_bool DALRemap);
161
162kal_int32 demp_CheckGoodBlock(kal_uint32 Block);
163
164kal_int32 demp_ReadPhysicalPage(kal_uint32 PhyBlock, kal_uint32 PhyPage, void * Data);
165
166#endif //_NAND_FLASH_BOOTING_
167
168#endif /*NAND_DAL_H*/