-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathmain.s
231 lines (189 loc) · 5.29 KB
/
main.s
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
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
// SPDX-FileCopyrightText: 2020-2021 Ivan Ivanov
// SPDX-License-Identifier: GPL-3.0-or-later
#include "soc/rtc_cntl_reg.h"
#include "soc/rtc_io_reg.h"
#include "soc/soc_ulp.h"
#include "stack.s"
.set SENSOR_INA219, 0x01
.set SENSOR_LSM6DS3, 0x02
.set SENSOR_MLX90615, 0x04
.set SENSOR_MAX30100, 0x08
.set SENSOR_BME280, 0x16
.bss
.global sample_counter
sample_counter:
.long 0
.global result
result:
.long 0
.global sensors_switch_extern
sensors_switch_extern:
.long 0
.global sensors_switch
sensors_switch:
.long 0
.global sensors_working // lsm6 use logic to on/off
sensors_working:
.long 0
.global refresh_sensors
refresh_sensors:
.long 0
.global ina219_read_cnt
ina219_read_cnt:
.long 0
.global lsm6ds3_read_cnt
lsm6ds3_read_cnt:
.long 0
.global mlx90615_read_cnt
mlx90615_read_cnt:
.long 0
.global max30100_read_cnt
max30100_read_cnt:
.long 0
.global bme280_read_cnt
bme280_read_cnt:
.long 0
.global ina219_skip_cnt
ina219_skip_cnt:
.long 0
.global lsm6ds3_skip_cnt
lsm6ds3_skip_cnt:
.long 0
.global mlx90615_skip_cnt
mlx90615_skip_cnt:
.long 0
.global max30100_skip_cnt
max30100_skip_cnt:
.long 0
.global bme280_skip_cnt
bme280_skip_cnt:
.long 0
.global ds3231_update_flag
ds3231_update_flag:
.long 0
.global stack
stack:
.skip 180
.global stackEnd
stackEnd:
.long 0
.text
.global entry
entry:
move r3, stackEnd
store_mem sensors_switch_extern sensors_switch
psr
jump ds3231_getDateTime // anyway at start, try to get current time
// jump inc_sample
move r2, ds3231_update_flag // update time logic if needed
ld r0,r2,0x0
jumpr skip_time_update, 0, eq
move r0, ds3231_set_year // skip update if year == 2000
jumpr skip_time_update, 0, eq
psr
jump ds3231_setDateTime
store ds3231_update_flag 0
store ds3231_set_day 0
skip_time_update:
// wake up some sensors while read other data
move r2, ds3231_second
ld r0, r2, 0x00
jumpr skip_wake_bme280, 89, lt // this is raw format from ds3231 > 59
// need some time to start after wake, so send wake first, do some work with other sensor and only than read
if_noflag sensors_switch SENSOR_MLX90615 skip_wake_mlx90615
psr
jump mlx90615_wake
skip_wake_mlx90615:
if_noflag sensors_switch SENSOR_BME280 skip_wake_bme280
psr
jump bme280_forceRead // do force read, after that it go to sleep mode, need some time to wake and read
skip_wake_bme280:
// this is a long long logic, i tried separate logic but it costs high-memory
if_flag sensors_switch SENSOR_INA219 start_read_ina219
inc ina219_skip_cnt
jump skip_read_ina219
start_read_ina219:
psr
jump ina219_readdata
inc ina219_read_cnt
skip_read_ina219:
if_flag sensors_switch SENSOR_MAX30100 start_read_max30100
inc max30100_skip_cnt
jump skip_read_max30100
start_read_max30100: // it runs once in beginnin of minute, and than wait until main core drops flag for new reading
if_flag max30100_flags 0x2 skip_read_max30100 // test for buffer is full
psr //
jump max30100_init // it takes 2 seconds (blocking state) // is's easyer, at least for now, in other case i shoul wake every 0.2 second to read fifo buffer
inc max30100_read_cnt
skip_read_max30100:
move r2, ds3231_second // read once in 2 second
ld r0, r2, 0x00 //
and r0, r0, 0x01 //
jumpr skip_read_lsm6ds3, 0x0, eq //
if_flag sensors_switch SENSOR_LSM6DS3 start_read_lsm6ds3
if_noflag sensors_working SENSOR_LSM6DS3 skip_read_lsm6ds3
psr
jump lsm6ds3_poweroff
del_flag sensors_working SENSOR_LSM6DS3
inc lsm6ds3_skip_cnt
jump skip_read_lsm6ds3
start_read_lsm6ds3:
move r2, 30 // mb problem
psr
jump waitMs
psr
jump lsm6ds3_config_pedometer
set_flag sensors_working SENSOR_LSM6DS3
inc lsm6ds3_read_cnt
skip_read_lsm6ds3:
move r2, ds3231_second
ld r0, r2, 0x00 // skip first bite - minute
jumpr inc_sample, 89, lt // this is raw format from ds3231 > 59
move r2, 30 // mb problem
psr
jump waitMs
if_flag sensors_switch SENSOR_BME280 start_read_bme280
inc bme280_skip_cnt
jump skip_read_bme280
start_read_bme280:
move r2, 10
psr
jump waitMs
psr
jump bme280_readdata
inc bme280_read_cnt
skip_read_bme280:
if_flag sensors_switch SENSOR_MLX90615 start_read_mlx90615
inc mlx90615_skip_cnt
jump skip_read_mlx90615
start_read_mlx90615:
psr
jump mlx90615_readdata
inc mlx90615_read_cnt
skip_read_mlx90615:
inc_sample:
inc sample_counter // Read sample counter
.global exit
exit:
halt
#if 0
.global wake_up
wake_up:
/* Check if the system can be woken up */
READ_RTC_REG(RTC_CNTL_DIAG0_REG, 19, 1)
and r0, r0, 1
jump exit, eq
/* Wake up the SoC, end program */
wake
WRITE_RTC_FIELD(RTC_CNTL_STATE0_REG, RTC_CNTL_ULP_CP_SLP_TIMER_EN, 0)
halt
#endif
// Wait for r2 milliseconds
.global waitMs
waitMs:
wait 8000
sub r2,r2,1
jump doneWaitMs,eq
jump waitMs
doneWaitMs:
ret