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