/
ESP8266_4MB.py
120 lines (115 loc) · 3 KB
/
ESP8266_4MB.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
#!/bin/false
# This file is part of Espruino, a JavaScript interpreter for Microcontrollers
#
# Copyright (C) 2013 Gordon Williams <gw@pur3.co.uk>
#
# 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 os;
import pinutils;
info = {
'name' : "ESP8266",
'espruino_page_link' : 'EspruinoESP8266',
'default_console' : "EV_SERIAL1",
'default_console_baudrate' : "115200",
'variables' : 1600,
'binary_name' : 'espruino_%v_esp8266_4mb',
'build' : {
'libraries' : [
'NET',
'TELNET',
'GRAPHICS',
'CRYPTO',
'NEOPIXEL',
#'FILESYSTEM',
#'FLASHFS'
],
'makefile' : [
'FLASH_4MB=1',
'ESP_FLASH_MAX=962560',
'FLASH_BAUD=460800'
]
}
};
chip = {
'part' : "ESP8266",
'family' : "ESP8266",
'package' : "",
'ram' : 80,
'flash' : 0,
'speed' : 160,
'usart' : 2,
'spi' : 1,
'i2c' : 1,
'adc' : 1,
'dac' : 0,
'saved_code' : {
# 0x000000 + 4096 * (256 - 16save - 1wifi -4reserved)
'address' : 0x0EB000, # first page is used for wifi save
'page_size' : 4096,
'pages' : 16,
'flash_available' : 940, # firmware can be up to this size
},
};
devices = {
};
# left-right, or top-bottom order
board_esp12 = {
'top' : ['D1', 'D3', 'D5', 'D4', 'D0', 'D2', 'D15', 'GND'],
'bottom' : ['VCC', 'D13', 'D12', 'D14', 'D16', 'CH_EN', 'A0', 'RESET'],
'right' : ['D11', 'D8', 'D9', 'D10', 'D7', 'D6'],
};
board_esp12["bottom"].reverse()
board_esp12["right"].reverse()
board_esp12["_css"] = """
#board {
width: 600px;
height: 384px;
left: 50px;
top: 100px;
background-image: url(img/ESP8266_12.jpg);
}
#boardcontainer {
height: 600px;
}
#board #right {
top: 60px;
left: 600px;
}
#board #top {
bottom: 360px;
left: 195px;
}
#board #bottom {
top: 365px;
left: 195px;
}
#board .rightpin {
height: 48px;
}
#board .toppin, #board .bottompin {
width: 44px;
}
""";
# left-right, or top-bottom order
board_esp01 = {
'left' : ['D3', 'D0', 'D2', 'GND'],
'right' : ['VCC', 'RESET', 'CH_PD', 'D1'],
'_hide_not_on_connectors' : True
};
boards = [ board_esp12 ];
def get_pins():
pins = pinutils.generate_pins(0,16)
pinutils.findpin(pins, "PD0", True)["functions"]["LED_1"]=0;
pinutils.findpin(pins, "PD1", True)["functions"]["USART0_TX"]=0;
pinutils.findpin(pins, "PD2", True)["functions"]["USART1_TX"]=0;
pinutils.findpin(pins, "PD3", True)["functions"]["USART0_RX"]=0;
# just fake pins D0 .. D16
return pins