1 /******************************************************************************
2  *
3  * Copyright(c) 2007 - 2017 Realtek Corporation.
4  *
5  * This program is free software; you can redistribute it and/or modify it
6  * under the terms of version 2 of the GNU General Public License as
7  * published by the Free Software Foundation.
8  *
9  * This program is distributed in the hope that it will be useful, but WITHOUT
10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
12  * more details.
13  *
14  *****************************************************************************/
15 
16 /* #include "Mp_Precomp.h" */
17 /* #include "../odm_precomp.h" */
18 
19 #include <drv_types.h>
20 #include "HalEfuseMask8703B_SDIO.h"
21 
22 
23 
24 /******************************************************************************
25 *                           MSDIO.TXT
26 ******************************************************************************/
27 
28 u8 Array_MP_8703B_MSDIO[] = {
29 	0xFF,
30 	0xF3,
31 	0x00,
32 	0x0E,
33 	0x70,
34 	0x00,
35 	0x00,
36 	0x00,
37 	0x00,
38 	0x00,
39 	0x00,
40 	0x07,
41 	0xF3,
42 	0xFF,
43 	0xFF,
44 	0xFF,
45 	0xFF,
46 	0xFF,
47 	0x00,
48 	0x00,
49 	0x00,
50 	0x00,
51 	0x00,
52 	0x00,
53 	0x00,
54 	0x00,
55 	0x00,
56 	0x00,
57 	0x00,
58 	0x00,
59 	0x00,
60 	0x00,
61 
62 };
63 
64 u16
EFUSE_GetArrayLen_MP_8703B_MSDIO(void)65 EFUSE_GetArrayLen_MP_8703B_MSDIO(void)
66 {
67 	return sizeof(Array_MP_8703B_MSDIO) / sizeof(u8);
68 }
69 
70 void
EFUSE_GetMaskArray_MP_8703B_MSDIO(u8 * Array)71 EFUSE_GetMaskArray_MP_8703B_MSDIO(
72 		u8 *Array
73 )
74 {
75 	u16 len = EFUSE_GetArrayLen_MP_8703B_MSDIO(), i = 0;
76 
77 	for (i = 0; i < len; ++i)
78 		Array[i] = Array_MP_8703B_MSDIO[i];
79 }
80 BOOLEAN
EFUSE_IsAddressMasked_MP_8703B_MSDIO(u16 Offset)81 EFUSE_IsAddressMasked_MP_8703B_MSDIO(
82 		u16 Offset
83 )
84 {
85 	int r = Offset / 16;
86 	int c = (Offset % 16) / 2;
87 	int result = 0;
88 
89 	if (c < 4) /* Upper double word */
90 		result = (Array_MP_8703B_MSDIO[r] & (0x10 << c));
91 	else
92 		result = (Array_MP_8703B_MSDIO[r] & (0x01 << (c - 4)));
93 
94 	return (result > 0) ? 0 : 1;
95 }
96