-
-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathplatf.h
153 lines (112 loc) · 3.58 KB
/
platf.h
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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
#ifndef _PLATF_H
#define _PLATF_H
/****** Platform-specific code and defines
*/
/* (c) copyright fenugrec 2016-2020
* GPLv3
*
*/
/****** kernel customization ******/
#define SCI_DEFAULTDIV 9 //default value for BRR reg. Speed (kbps) = (20 * 1000) / (32 * (BRR + 1))
/* Uncomment to enable verification of succesful block erase . Adds 128B for the block descriptors + ~ 44B of code */
//#define POSTERASE_VERIFY
/* Uncomment to add diag function for atomic u16 reads */
//#define DIAG_U16READ
/* Uncomment to taint WDT pulse for debug use */
//#define DIAG_TAINTWDT
#include <stdbool.h>
/****** mfg- and mcu-specific defines ******
*
* RAM_MIN, RAM_MAX : whole RAM area
* " #include "reg_defines/????" : i/o peripheral registers
*/
/*** WDT and master clock stuff
* want to toggle the WDT every X ms (2ms on Nissan)
*/
//#define WDT_PER_MS 2
/* somehow shc sucks at reducing the following :
* u16 WDT_MAXCNT = WDT_PER_MS / 1000 * (40*1000*1000ULL / 64))
*/
//#define WDT_MAXCNT WDT_PER_MS * 40*1000*1000UL / 64 / 1000
#if defined(npk)
#define WDT_MAXCNT 1250
/* Nissan only: RAMJUMP_PRELOAD_META : pre-ramjump metadata address */
#if defined(SH7058)
#include "reg_defines/7058.h"
#define RAM_MIN 0xFFFF0000
#define RAM_MAX 0xFFFFBFFF
#define RAMJUMP_PRELOAD_META 0xffff8000
#define NPK_SCI SCI1
#elif defined(SH7055_18)
#include "reg_defines/7055_180nm.h"
#define RAM_MIN 0xFFFF6000
#define RAM_MAX 0xFFFFDFFF
#define RAMJUMP_PRELOAD_META 0xffff8000
#define NPK_SCI SCI1
#elif defined(SH7055_35)
#include "reg_defines/7055_350nm.h"
#define RAM_MIN 0xFFFF6000
#define RAM_MAX 0xFFFFDFFF
#define RAMJUMP_PRELOAD_META 0xffff8000
#define NPK_SCI SCI1
#elif defined(SH7051)
#include "reg_defines/7051.h"
#define RAM_MIN 0xFFFFD800
#define RAM_MAX 0xFFFFFFFF
#define RAMJUMP_PRELOAD_META 0xffffD800
#define NPK_SCI SCI2
#else
#error No target specified !
#endif
#elif defined(ssmk)
#define WDT_MAXCNT 4125 //aim for 6.6ms , although it probably works at 2ms anyway
#if defined(SH7058)
#include "reg_defines/7058.h"
#define RAM_MIN 0xFFFF0000
#define RAM_MAX 0xFFFFBFFF
#define NPK_SCI SCI2
#elif defined(SH7055_18)
#include "reg_defines/7055_180nm.h"
#define RAM_MIN 0xFFFF6000
#define RAM_MAX 0xFFFFDFFF
#define NPK_SCI SCI2
#else
#error invalid target for ssmk
#endif
#endif
#define MCLK_GETMS(x) ((x) * 16 / 10000) /* convert ticks to milliseconds */
#define MCLK_GETTS(x) ((x) * 10000 / 16) /* convert millisec to ticks */
#define MCLK_MAXSPAN 10000 /* arbitrary limit (in ms) for time spans measured by MCLK */
/** Get current timestamp from free-running counter */
//uint32_t get_mclk_ts(void);
#define get_mclk_ts(x) (ATU0.TCNT)
/** Ret 1 if ok
*
* sets *err to a negative response code if failed
*/
bool platf_flash_init(uint8_t *err);
/** Enable modification (erase/write) to flash.
*
* If this is not called after platf_flash_init(), the actual calls to erase / write flash are skipped
*/
void platf_flash_unprotect(void);
/** Erase block, see definition of blocks in DS.
*
* ret 0 if ok
*/
uint32_t platf_flash_eb(unsigned blockno);
/** Write block of data. len must be multiple of SIDFL_WB_DLEN
*
*
* @return 0 if ok , response code ( > 0x80) if failed.
*
* Note : the implementation must not assume that the src address will be 4-byte aligned !
*/
uint32_t platf_flash_wb(uint32_t dest, uint32_t src, uint32_t len);
/***** Init funcs ****/
/** init platform-specific stuff : SCI, clocks, interrupts, WDT etc */
void init_platf(void);
/** force reset by external supervisor and/or internal WDT.
*/
void die(void);
#endif