forked from espruino/Espruino
-
Notifications
You must be signed in to change notification settings - Fork 0
/
RAK5010.py
168 lines (157 loc) · 5.94 KB
/
RAK5010.py
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
#!/bin/false
# This file is part of Espruino, a JavaScript interpreter for Microcontrollers
#
# Copyright (C) 2020 Gordon Williams <[email protected]>
#
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
#
# ----------------------------------------------------------------------------------------
# This file contains information for a specific board - the available pins, and where LEDs,
# Buttons, and other in-built peripherals are. It is used to build documentation as well
# as various source and header files for Espruino.
# ----------------------------------------------------------------------------------------
import pinutils;
# Schematic https://doc.rakwireless.com/datasheet/rakproducts/schematic-diagram---rak5010-wistrio
info = {
'name' : "RAK5010 WisTrio NB-IoT Tracker",
'link' : [ "https://doc.rakwireless.com/datasheet/rakproducts/rak5010-wistrio-nb-iot-tracker-datasheet" ],
'espruino_page_link' : 'RAK5010',
'variables' : 12500, # How many variables are allocated for Espruino to use. RAM will be overflowed if this number is too high and code won't compile.
# 'bootloader' : 1,
'default_console' : "EV_BLUETOOTH",
# 'default_console_tx' : "D34", # IO3
# 'default_console_rx' : "D33", # IO4
# 'default_console_baudrate' : "9600",
'binary_name' : 'espruino_%v_RAK5010.hex',
'build' : {
'optimizeflags' : '-Os',
'libraries' : [
'BLUETOOTH',
'NET',
'CRYPTO','SHA256','SHA512',
'TLS',
],
'makefile' : [
'DEFINES+=-DCONFIG_GPIO_AS_PINRESET', # Allow the reset pin to work
'DEFINES+=-DCONFIG_NFCT_PINS_AS_GPIOS', # Don't use NFC - the pins are used for GPS
'DEFINES += -DNRF_USB=1 -DUSB', # USB only works if connected at startup
'DEFINES+=-DESPR_REGOUT0_1_8V=1', # Force RAK5010 nRF52 voltage regulator to 1.8v, which stops glitches in modem serial comms
'NRF_SDK15=1',
'DEFINES+=-DBLUETOOTH_NAME_PREFIX=\'"iTracker"\'',
'DFU_PRIVATE_KEY=targets/nrf5x_dfu/dfu_private_key.pem',
'DFU_SETTINGS=--application-version 0xff --hw-version 52 --sd-req 0x8C,0x91',
'JSMODULESOURCES += libs/js/AT.min.js',
'JSMODULESOURCES += libs/js/GPS.min.js',
'JSMODULESOURCES += libs/js/LIS3DH.min.js',
'JSMODULESOURCES += libs/js/OPT3001.min.js',
'JSMODULESOURCES += libs/js/LPS22HB.min.js',
'JSMODULESOURCES += libs/js/SHT3C.min.js',
'JSMODULESOURCES += libs/js/ATSMS.min.js',
'JSMODULESOURCES += libs/js/QuectelBG96.min.js',
'JSMODULESOURCES += iTracker:libs/js/rak/RAK5010.js' # should probably use minified
]
}
};
chip = {
'part' : "NRF52840",
'family' : "NRF52",
'package' : "AQFN73",
'ram' : 256,
'flash' : 1024,
'speed' : 64,
'usart' : 2,
'spi' : 3,
'i2c' : 2,
'adc' : 1,
'dac' : 0,
'saved_code' : {
# Use this for on-chip flash
'address' : ((246 - 20) * 4096), # Bootloader takes pages 248-255, FS takes 246-247
'page_size' : 4096,
'pages' : 20,
'flash_available' : 1024 - ((31 + 8 + 2 + 20)*4) # Softdevice uses 31 pages of flash, bootloader 8, FS 2, code 20. Each page is 4 kb.
# Use this for the 8mb external flash if chip is installed in board
# 'address' : 0x60000000, # put this in external spiflash (see below)
# 'page_size' : 4096,
# 'pages' : 2048, # Entire 8MB of external flash
# 'flash_available' : 512 - ((31 + 8 + 2)*4) # Softdevice uses 31 pages of flash, bootloader 8, FS 2. Each page is 4 kb.
},
};
devices = {
'LED1' : { 'pin' : 'D12' },
# IS25WP064A QSPI flash
# 'SPIFLASH' : { # Chip is not installed in board
# 'pin_cs' : 'D42', # cs P1.10
# 'pin_sck' : 'D43', # clk P1.11
# 'pin_mosi' : 'D3', # d0 P0.03
# 'pin_miso' : 'D47', # d1 P1.15
# 'pin_wp' : 'D46', # d2 P1.14
# 'pin_rst' : 'D45', # d3 P1.13
# 'size' : 8192*1024, # 8MB
# 'memmap_base' : 0x60000000 # map into the address space (in software)
# }
};
# left-right, or top-bottom order
board = {
'right' : [ 'GND', 'VBAT', 'D5', 'D19', '',
'VREF', 'D20', 'D34', 'D33', '',
'3V', 'SWDIO', 'SWDCLK', 'GND' ],
'bottom' : ['MODEM PWR','RESET'],
'_hide_not_on_connectors' : True,
'_notes' : {
'D21' : "Also RESET if configured",
'D33' : "Labelled IO4 (requires VREF to be connected to 3V)",
'D34' : "Labelled IO3 (requires VREF to be connected to 3V)",
'D20' : "Labelled IO2 (requires VREF to be connected to 3V)",
'D19' : "Labelled IO1 (requires VREF to be connected to 3V)",
'D5' : "Labelled AIN"
}
};
board["right"].reverse();
board["_css"] = """
#board {
width: 465px;
height: 526px;
top: 0px;
left : 0px;
background-image: url(img/RAK5010.png);
}
#boardcontainer {
height: 506px;
}
#right {
top: 55px;
left: 470px;
}
.rightpin {
height: 26px;
}
#bottom {
top: 504px;
left: 172px;
}
.bottompin {
transform: none;
width : 120px;
}
""";
def get_pins():
pins = pinutils.generate_pins(0,47) # 48 General Purpose I/O Pins.
# Add pin functions
pinutils.findpin(pins, "PD0", True)["functions"]["XL1"]=0;
pinutils.findpin(pins, "PD1", True)["functions"]["XL2"]=0;
pinutils.findpin(pins, "PD2", True)["functions"]["ADC1_IN0"]=0;
pinutils.findpin(pins, "PD3", True)["functions"]["ADC1_IN1"]=0;
pinutils.findpin(pins, "PD4", True)["functions"]["ADC1_IN2"]=0;
pinutils.findpin(pins, "PD5", True)["functions"]["ADC1_IN3"]=0;
pinutils.findpin(pins, "PD28", True)["functions"]["ADC1_IN4"]=0;
pinutils.findpin(pins, "PD29", True)["functions"]["ADC1_IN5"]=0;
pinutils.findpin(pins, "PD30", True)["functions"]["ADC1_IN6"]=0;
pinutils.findpin(pins, "PD31", True)["functions"]["ADC1_IN7"]=0;
# everything is non-5v tolerant
for pin in pins:
pin["functions"]["3.3"]=0;
#The boot/reset button will function as a reset button in normal operation. Pin reset on PD21 needs to be enabled on the nRF52832 device for this to work.
return pins