gr533x_chip_trim.h
Go to the documentation of this file.
1 /**
2  *******************************************************************************
3  *
4  * @file gr533x_chip_trim.h
5  *
6  * @brief GR533X chip trim
7  *
8  *******************************************************************************
9  * @attention
10  #####Copyright (c) 2019 GOODIX
11  All rights reserved.
12 
13  Redistribution and use in source and binary forms, with or without
14  modification, are permitted provided that the following conditions are met:
15  * Redistributions of source code must retain the above copyright
16  notice, this list of conditions and the following disclaimer.
17  * Redistributions in binary form must reproduce the above copyright
18  notice, this list of conditions and the following disclaimer in the
19  documentation and/or other materials provided with the distribution.
20  * Neither the name of GOODIX nor the names of its contributors may be used
21  to endorse or promote products derived from this software without
22  specific prior written permission.
23 
24  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
25  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
26  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
27  ARE DISCLAIMED. IN NO EVENT SHALL COPYRIGHT HOLDERS AND CONTRIBUTORS BE
28  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
29  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
30  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
31  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
32  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
33  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
34  POSSIBILITY OF SUCH DAMAGE.
35  *****************************************************************************************
36  */
37 
38 /**
39  @addtogroup SYSTEM
40  @{
41  */
42 
43 /**
44  * @addtogroup SYS System SDK
45  * @{
46  * @brief Definitions and prototypes for the system SDK interface.
47 */
48 
49 #ifndef __GR533X_CHIP_TRIM_H__
50 #define __GR533X_CHIP_TRIM_H__
51 
52 #include<stdio.h>
53 #include<stdint.h>
54 
55 #define CHIP_TRIM_PATTERN (0x4744)
56 
57 typedef struct
58 {
59  uint16_t ate_version;
60  uint16_t hw_version;
61  uint16_t chip_id;
62  uint16_t package;
63  uint16_t flash_size;
64  uint16_t ram_size;
65  uint8_t unused[12];
66 } __attribute__ ((packed)) production_t;
67 
68 typedef struct
69 {
70  uint8_t tx_power;
71  uint8_t rssi_cali;
72  uint8_t hp_gain;
73  uint8_t unused[1];
74 } __attribute__ ((packed)) rf_trim_t;
75 
76 typedef struct
77 {
78  uint8_t dcdc_1p05;
79  uint8_t dcdc_1p15;
84  uint8_t sys_ldo_1p05;
85  uint8_t sys_ldo_1p15;
86  uint8_t io_ldo_1p8;
87  uint8_t io_ldo_3p0;
88  uint8_t stb_io_ldo_1P8;
89  uint8_t stb_io_ldo_3p0;
90  uint8_t unused[4];
91 } __attribute__ ((packed)) pmu_trim_t;
92 
93 typedef struct
94 {
95  uint16_t offset_int_0p8; /* Offset based on interanl reference(0.85V) */
96  uint16_t slope_int_0p8; /* Slope based on interanl reference(0.85V) */
97  uint16_t offset_int_1p2; /* Offset based on interanl reference(1.28V) */
98  uint16_t slope_int_1p2; /* Slope based on interanl reference(1.28V) */
99  uint16_t offset_int_1p6; /* Offset based on interanl reference(0.85V) */
100  uint16_t slope_int_1p6; /* Offset based on interanl reference(0.85V) */
101  uint16_t offset_ext_1p0; /* Offset based on interanl reference(1.6V) */
102  uint16_t slope_ext_1p0; /* Slope based on interanl reference(1.6V) */
103  uint16_t temp; /* Offset based on interanl reference(0.85V) */
104  uint16_t temp_ref; /* Chip temperature sensor reference temperature. E.g. Decimal 2618: 26.18ˇăC */
105  uint8_t unused[4];
106 } __attribute__ ((packed)) sadc_trim_t;
107 
108 typedef struct
109 {
110  uint16_t hf_osc_192m;
112  uint8_t unused[4];
113 } __attribute__ ((packed)) clk_trim_t;
114 
115 typedef struct
116 {
117  uint8_t flash_manufacturer; /* flash manufacturer type PUYA: P25Q40SU: 0x11 */
118  uint8_t feature; /* 0bit: 1 ~ support 512byte write, 0 ~ not support 512 byte write */
119  uint8_t flash_tVSL; /* VCC(min.) to device operation. Uint: 10us */
120  uint8_t flash_tESL; /* Erase suspend latency. Uint: 5us */
121  uint8_t flash_tPSL; /* Program suspend latency. Uint: 5us */
122  uint8_t flash_tPRS; /* Latency between program resume and next suspend. Uint: 5us */
123  uint8_t flash_tERS; /* Latency between erase resume and next suspend. Uint: 5us */
124  uint8_t flash_tDP; /* CS# High to Deep Power-down Mode. Uint: 5us */
125  uint8_t flash_tRES2; /* CS# High To Standby Mode With Electronic Signature Read. Uint: 5us */
126  uint8_t flash_tRDINT; /* Read status register interval when wait busy. Uint: 5us */
127  uint8_t unused[2];
128 } __attribute__ ((packed)) flash_timing_t;
129 
130 typedef struct {
131  uint16_t pattern;
132  uint16_t item_end;
133  uint32_t check_sum;
134  production_t prod;
135  rf_trim_t rf;
136  pmu_trim_t pmu;
137  sadc_trim_t sadc;
138  clk_trim_t clk;
139  flash_timing_t flash;
140 // uint8_t unused[168];
141 } __attribute__ ((packed)) chip_trim0_t;
142 
143 typedef struct {
144  uint8_t bt_addr[6];
145  uint16_t xo_offset;
146 // uint8_t reserved[24];
147 // uint8_t user[224];
148 } __attribute__ ((packed)) chip_trim1_t;
149 
150 
151 /** @} */
152 #endif
153 
154 /** @} */
__attribute__::rssi_cali
uint8_t rssi_cali
Definition: gr533x_chip_trim.h:71
__attribute__::dig_ldo_0P9_fine
uint8_t dig_ldo_0P9_fine
Definition: gr533x_chip_trim.h:81
__attribute__::temp
uint16_t temp
Definition: gr533x_chip_trim.h:103
__attribute__::rf
rf_trim_t rf
Definition: gr533x_chip_trim.h:135
__attribute__::offset_int_1p2
uint16_t offset_int_1p2
Definition: gr533x_chip_trim.h:97
__attribute__::stb_io_ldo_1P8
uint8_t stb_io_ldo_1P8
Definition: gr533x_chip_trim.h:88
__attribute__::chip_id
uint16_t chip_id
Definition: gr533x_chip_trim.h:61
__attribute__::feature
uint8_t feature
Definition: gr533x_chip_trim.h:118
__attribute__::flash_tRES2
uint8_t flash_tRES2
Definition: gr533x_chip_trim.h:125
__attribute__::package
uint16_t package
Definition: gr533x_chip_trim.h:62
__attribute__::check_sum
uint32_t check_sum
Definition: gr533x_chip_trim.h:133
__attribute__::prod
production_t prod
Definition: gr533x_chip_trim.h:134
__attribute__::pattern
uint16_t pattern
Definition: gr533x_chip_trim.h:131
__attribute__::dcdc_1p05
uint8_t dcdc_1p05
Definition: gr533x_chip_trim.h:78
__attribute__::flash_tVSL
uint8_t flash_tVSL
Definition: gr533x_chip_trim.h:119
__attribute__::ram_size
uint16_t ram_size
Definition: gr533x_chip_trim.h:64
__attribute__::dcdc_1p15
uint8_t dcdc_1p15
Definition: gr533x_chip_trim.h:79
__attribute__::hw_version
uint16_t hw_version
Definition: gr533x_chip_trim.h:60
__attribute__::slope_int_1p6
uint16_t slope_int_1p6
Definition: gr533x_chip_trim.h:100
__attribute__::hf_osc_192m_fine
uint16_t hf_osc_192m_fine
Definition: gr533x_chip_trim.h:111
__attribute__::hf_osc_192m
uint16_t hf_osc_192m
Definition: gr533x_chip_trim.h:110
__attribute__::offset_int_1p6
uint16_t offset_int_1p6
Definition: gr533x_chip_trim.h:99
__attribute__::sys_ldo_1p05
uint8_t sys_ldo_1p05
Definition: gr533x_chip_trim.h:84
__attribute__::offset_int_0p8
uint16_t offset_int_0p8
Definition: gr533x_chip_trim.h:95
__attribute__::ate_version
uint16_t ate_version
Definition: gr533x_chip_trim.h:59
__attribute__::dig_ldo_1p05_coarse
uint8_t dig_ldo_1p05_coarse
Definition: gr533x_chip_trim.h:82
__attribute__::sadc
sadc_trim_t sadc
Definition: gr533x_chip_trim.h:137
__attribute__::io_ldo_3p0
uint8_t io_ldo_3p0
Definition: gr533x_chip_trim.h:87
__attribute__::clk
clk_trim_t clk
Definition: gr533x_chip_trim.h:138
__attribute__::offset_ext_1p0
uint16_t offset_ext_1p0
Definition: gr533x_chip_trim.h:101
__attribute__::flash_manufacturer
uint8_t flash_manufacturer
Definition: gr533x_chip_trim.h:117
__attribute__::tx_power
uint8_t tx_power
Definition: gr533x_chip_trim.h:70
__attribute__::slope_int_0p8
uint16_t slope_int_0p8
Definition: gr533x_chip_trim.h:96
__attribute__::slope_ext_1p0
uint16_t slope_ext_1p0
Definition: gr533x_chip_trim.h:102
__attribute__::io_ldo_1p8
uint8_t io_ldo_1p8
Definition: gr533x_chip_trim.h:86
__attribute__
Definition: gr533x_chip_trim.h:58
__attribute__::stb_io_ldo_3p0
uint8_t stb_io_ldo_3p0
Definition: gr533x_chip_trim.h:89
__attribute__::pmu
pmu_trim_t pmu
Definition: gr533x_chip_trim.h:136
__attribute__::temp_ref
uint16_t temp_ref
Definition: gr533x_chip_trim.h:104
__attribute__::flash_tESL
uint8_t flash_tESL
Definition: gr533x_chip_trim.h:120
__attribute__::hp_gain
uint8_t hp_gain
Definition: gr533x_chip_trim.h:72
__attribute__::flash_tERS
uint8_t flash_tERS
Definition: gr533x_chip_trim.h:123
__attribute__::flash_tPRS
uint8_t flash_tPRS
Definition: gr533x_chip_trim.h:122
__attribute__::dig_ldo_0p9_coarse
uint8_t dig_ldo_0p9_coarse
Definition: gr533x_chip_trim.h:80
__attribute__::flash
flash_timing_t flash
Definition: gr533x_chip_trim.h:139
__attribute__::sys_ldo_1p15
uint8_t sys_ldo_1p15
Definition: gr533x_chip_trim.h:85
__attribute__::item_end
uint16_t item_end
Definition: gr533x_chip_trim.h:132
__attribute__::flash_size
uint16_t flash_size
Definition: gr533x_chip_trim.h:63
__attribute__::flash_tRDINT
uint8_t flash_tRDINT
Definition: gr533x_chip_trim.h:126
__attribute__::dig_ldo_1p05_fine
uint8_t dig_ldo_1p05_fine
Definition: gr533x_chip_trim.h:83
__attribute__::xo_offset
uint16_t xo_offset
Definition: gr533x_chip_trim.h:145
__attribute__::flash_tDP
uint8_t flash_tDP
Definition: gr533x_chip_trim.h:124
__attribute__::slope_int_1p2
uint16_t slope_int_1p2
Definition: gr533x_chip_trim.h:98
__attribute__::flash_tPSL
uint8_t flash_tPSL
Definition: gr533x_chip_trim.h:121