nodemcu-firmware/README.md

340 lines
9.4 KiB
Markdown
Raw Normal View History

2014-11-13 00:17:08 +08:00
# **NodeMcu** #
version 0.9.5
2014-11-13 00:17:08 +08:00
###A lua based firmware for wifi-soc esp8266
2015-01-24 23:36:04 +08:00
Build on [ESP8266 sdk 0.9.5](http://bbs.espressif.com/viewtopic.php?f=5&t=154)<br />
2014-12-22 19:37:49 +08:00
Lua core based on [eLua project](http://www.eluaproject.net/)<br />
File system based on [spiffs](https://github.com/pellepl/spiffs)<br />
Open source development kit for NodeMCU [nodemcu-devkit](https://github.com/nodemcu/nodemcu-devkit)<br />
Flash tool for NodeMCU [nodemcu-flasher](https://github.com/nodemcu/nodemcu-flasher)<br />
2014-12-22 19:37:49 +08:00
wiki: [nodemcu wiki](https://github.com/nodemcu/nodemcu-firmware/wiki)<br />
2015-01-25 12:10:40 +08:00
api: [nodemcu api](https://github.com/nodemcu/nodemcu-firmware/wiki/nodemcu_api_en)<br />
2014-12-22 19:37:49 +08:00
home: [nodemcu.com](http://www.nodemcu.com)<br />
bbs: [Chinese bbs](http://bbs.nodemcu.com)<br />
Tencent QQ group: 309957875<br />
2015-01-06 21:52:14 +08:00
# Summary
- Easy to access wireless router
- Based on Lua 5.1.4 (without *io, math, debug, os* module.)
- Event-Drive programming preferred.
2015-01-24 23:36:04 +08:00
- Build-in file, timer, pwm, i2c, spi, 1-wire, net, mqtt, gpio, wifi, adc, uart and system api.
2015-01-06 21:52:14 +08:00
- GPIO pin re-mapped, use the index to access gpio, i2c, pwm.
# To Do List (pull requests are very welcomed)
- fix wifi smart connect
2015-01-24 23:36:04 +08:00
- add spi module (done)
- add mqtt module (done)
2015-01-06 21:52:14 +08:00
- add coap module
2015-01-24 23:36:04 +08:00
- cross compiler
2015-01-06 21:52:14 +08:00
2015-01-26 23:41:24 +08:00
# Change log
2015-02-13 15:11:59 +08:00
2015-02-13<br />
add node.compile() api to compile lua text file into lua bytecode file.<br />
this will reduce memory usage noticeably when require modules into NodeMCU.<br />
raise internal LUA_BUFFERSIZE from 1024 to 4096.<br />
lua require("mod") will load "mod.lc" file first if exist.<br />
build latest pre_build bin.
2015-02-12 11:31:06 +08:00
2015-02-12<br />
fix float print.<br />
update spiffs, add file.rename api to file module.<br />
fix some file system bug. need more tests.<br />
add support to 8Mbyte, 16Mbyte flash.<br />
remove node.led() and node.key() api.<br />
some update to lua_modules and examples.<br />
build latest pre_build bin.
2015-01-27<br />
2015-01-27 13:56:34 +08:00
support floating point LUA.<br />
use macro LUA_NUMBER_INTEGRAL in user_config.h control this feature.<br />
LUA_NUMBER_INTEGRAL to disable floating point support,<br />
// LUA_NUMBER_INTEGRAL to enable floating point support.<br />
2015-01-27 20:47:41 +08:00
fix tmr.time(). #132<br />
fix filesystem length. #113<br />
fix ssl reboots. #134<br />
build pre_build bin.
2015-01-26 23:41:24 +08:00
2015-01-26<br />
2015-01-27 13:56:34 +08:00
applied sdk095_patch1 to sdk 0.9.5.<br />
added LUA examples and modules [by dvv](https://github.com/dvv). <br />
added node.readvdd33() API [by alonewolfx2](https://github.com/alonewolfx2).<br />
2015-01-26 23:41:24 +08:00
build pre_build bin.
2015-01-25 12:10:40 +08:00
[more change log](https://github.com/nodemcu/nodemcu-firmware/wiki)<br />
2014-11-07 12:59:19 +08:00
##GPIO NEW TABLE ( Build 20141219 and later)
<a id="new_gpio_map"></a>
<table>
<tr>
<th scope="col">IO index</th><th scope="col">ESP8266 pin</th><th scope="col">IO index</th><th scope="col">ESP8266 pin</th>
</tr>
<tr>
<td>0 [*]</td><td>GPIO16</td><td>8</td><td>GPIO15</td>
</tr>
<tr>
<td>1</td><td>GPIO5</td><td>9</td><td>GPIO3</td>
</tr>
<tr>
<td>2</td><td>GPIO4</td><td>10</td><td>GPIO1</td>
</tr>
<tr>
<td>3</td><td>GPIO0</td><td>11</td><td>GPIO9</td>
</tr>
<tr>
<td>4</td><td>GPIO2</td><td>12</td><td>GPIO10</td>
</tr>
<tr>
<td>5</td><td>GPIO14</td><td></td><td></td>
</tr>
<tr>
<td>6</td><td>GPIO12</td><td></td><td></td>
</tr>
<tr>
<td>7</td><td>GPIO13</td<td></td><td></td>
</tr>
</table>
#### [*] D0(GPIO16) can only be used as gpio read/write. no interrupt supported. no pwm/i2c/ow supported.
#Build option
####file ./app/include/user_config.h
```c
// #define FLASH_512K
// #define FLASH_1M
// #define FLASH_2M
// #define FLASH_4M
#define FLASH_AUTOSIZE
...
#define LUA_USE_MODULES
#ifdef LUA_USE_MODULES
#define LUA_USE_MODULES_NODE
#define LUA_USE_MODULES_FILE
#define LUA_USE_MODULES_GPIO
#define LUA_USE_MODULES_WIFI
#define LUA_USE_MODULES_NET
#define LUA_USE_MODULES_PWM
#define LUA_USE_MODULES_I2C
#define LUA_USE_MODULES_TMR
#define LUA_USE_MODULES_ADC
#define LUA_USE_MODULES_UART
#define LUA_USE_MODULES_OW
#define LUA_USE_MODULES_BIT
#define LUA_USE_MODULES_WS2812
#endif /* LUA_USE_MODULES */
...
// LUA_NUMBER_INTEGRAL
```
2014-11-07 12:59:19 +08:00
2014-11-13 00:17:08 +08:00
#Flash the firmware
nodemcu_latest.bin: 0x00000<br />
for most esp8266 modules, just pull GPIO0 down and restart.<br />
You can use the [nodemcu-flasher](https://github.com/nodemcu/nodemcu-flasher) to burn the firmware.
2014-11-11 12:31:45 +08:00
2014-12-22 20:20:20 +08:00
Or, if you build your own bin from source code.<br />
2015-01-24 23:36:04 +08:00
0x00000.bin: 0x00000<br />
0x10000.bin: 0x10000<br />
2014-12-22 20:20:20 +08:00
*Better run file.format() after flash*
2014-12-22 20:20:20 +08:00
2014-11-13 00:17:08 +08:00
#Connect the hardware in serial
baudrate:9600
2014-11-11 12:31:45 +08:00
2014-11-13 00:17:08 +08:00
#Start play
2014-11-11 12:31:45 +08:00
2014-11-13 00:17:08 +08:00
####Connect to your ap
2014-10-13 20:24:52 +08:00
2014-11-13 00:17:08 +08:00
```lua
ip = wifi.sta.getip()
print(ip)
--nil
2014-11-07 12:59:19 +08:00
wifi.setmode(wifi.STATION)
2014-11-13 00:17:08 +08:00
wifi.sta.config("SSID","password")
ip = wifi.sta.getip()
print(ip)
2014-11-13 00:17:08 +08:00
--192.168.18.110
2014-11-07 12:59:19 +08:00
```
2014-10-13 20:24:52 +08:00
2014-11-13 00:17:08 +08:00
####Manipulate hardware like a arduino
```lua
pin = 1
gpio.mode(pin,gpio.OUTPUT)
gpio.write(pin,gpio.HIGH)
print(gpio.read(pin))
2014-11-07 12:59:19 +08:00
```
2014-10-13 20:24:52 +08:00
2014-11-13 00:17:08 +08:00
####Write network application in nodejs style
```lua
-- A simple http client
conn=net.createConnection(net.TCP, 0)
2014-11-25 19:28:44 +08:00
conn:on("receive", function(conn, payload) print(payload) end )
2014-11-13 00:17:08 +08:00
conn:connect(80,"115.239.210.27")
conn:send("GET / HTTP/1.1\r\nHost: www.baidu.com\r\n"
.."Connection: keep-alive\r\nAccept: */*\r\n\r\n")
2014-11-07 12:59:19 +08:00
```
2014-10-13 20:24:52 +08:00
2015-01-26 23:50:40 +08:00
####Or a simple http server
```lua
-- A simple http server
srv=net.createServer(net.TCP)
srv:listen(80,function(conn)
conn:on("receive",function(conn,payload)
print(payload)
conn:send("<h1> Hello, NodeMcu.</h1>")
end)
conn:on("sent",function(conn) conn:close() end)
end)
```
####Connect to MQTT Broker
```lua
-- init mqtt client with keepalive timer 120sec
m = mqtt.Client("clientid", 120, "user", "password")
-- setup Last Will and Testament (optional)
-- Broker will publish a message with qos = 0, retain = 0, data = "offline"
-- to topic "/lwt" if client don't send keepalive packet
m:lwt("/lwt", "offline", 0, 0)
m:on("connect", function(con) print ("connected") end)
m:on("offline", function(con) print ("offline") end)
-- on publish message receive event
m:on("message", function(conn, topic, data)
print(topic .. ":" )
if data ~= nil then
print(data)
end
end)
-- for secure: m:connect("192.168.11.118", 1880, 1)
m:connect("192.168.11.118", 1880, 0, function(conn) print("connected") end)
-- subscribe topic with qos = 0
m:subscribe("/topic",0, function(conn) print("subscribe success") end)
-- or subscribe multiple topic (topic/0, qos = 0; topic/1, qos = 1; topic2 , qos = 2)
-- m:subscribe({["topic/0"]=0,["topic/1"]=1,topic2=2}, function(conn) print("subscribe success") end)
-- publish a message with data = hello, QoS = 0, retain = 0
m:publish("/topic","hello",0,0, function(conn) print("sent") end)
m:close();
-- you can call m:connect again
```
2015-01-26 23:50:40 +08:00
#### UDP client and server
2014-11-13 00:17:08 +08:00
```lua
2015-01-26 23:50:40 +08:00
-- a udp server
s=net.createServer(net.UDP)
s:on("receive",function(s,c) print(c) end)
s:listen(5683)
-- a udp client
cu=net.createConnection(net.UDP)
cu:on("receive",function(cu,c) print(c) end)
cu:connect(5683,"192.168.18.101")
cu:send("hello")
2014-11-13 00:17:08 +08:00
```
####Do something shining
```lua
function led(r,g,b)
pwm.setduty(1,r)
pwm.setduty(2,g)
pwm.setduty(3,b)
2014-11-13 00:17:08 +08:00
end
2014-11-29 23:33:45 +08:00
pwm.setup(1,500,512)
pwm.setup(2,500,512)
pwm.setup(3,500,512)
2014-11-13 00:17:08 +08:00
pwm.start(1)
pwm.start(2)
pwm.start(3)
2014-11-29 23:33:45 +08:00
led(512,0,0) -- red
led(0,0,512) -- blue
2014-11-13 00:17:08 +08:00
```
####And blink it
```lua
lighton=0
tmr.alarm(1,1000,1,function()
2014-11-13 00:17:08 +08:00
if lighton==0 then
lighton=1
2014-11-29 23:33:45 +08:00
led(512,512,512)
2014-11-13 00:17:08 +08:00
else
lighton=0
led(0,0,0)
end
end)
```
####If you want to run something when system started
```lua
--init.lua will be excuted
file.open("init.lua","w")
file.writeline([[print("Hello, do this at the beginning.")]])
file.close()
node.restart() -- this will restart the module.
```
2014-11-18 19:58:48 +08:00
####With below code, you can telnet to your esp8266 now
```lua
-- a simple telnet server
2014-11-22 21:24:51 +08:00
s=net.createServer(net.TCP,180)
2014-11-18 19:58:48 +08:00
s:listen(2323,function(c)
function s_output(str)
2014-11-22 21:24:51 +08:00
if(c~=nil)
then c:send(str)
2014-11-18 19:58:48 +08:00
end
end
node.output(s_output, 0) -- re-direct output to function s_ouput.
c:on("receive",function(c,l)
node.input(l) -- works like pcall(loadstring(l)) but support multiple separate line
end)
c:on("disconnection",function(c)
node.output(nil) -- un-regist the redirect output function, output goes to serial
end)
2014-11-22 21:24:51 +08:00
print("Welcome to NodeMcu world.")
2014-11-18 19:58:48 +08:00
end)
```
####Use DS18B20 module extends your esp8266
```lua
-- read temperature with DS18B20
2015-02-13 15:11:59 +08:00
node.compile("ds18b20.lua") -- run this only once to compile and save to "ds18b20.lc"
t=require("ds18b20")
t.setup(9)
addrs=t.addrs()
-- Total DS18B20 numbers, assume it is 2
print(table.getn(addrs))
-- The first DS18B20
print(t.read(addrs[1],t.C))
print(t.read(addrs[1],t.F))
print(t.read(addrs[1],t.K))
-- The second DS18B20
print(t.read(addrs[2],t.C))
print(t.read(addrs[2],t.F))
print(t.read(addrs[2],t.K))
-- Just read
print(t.read())
-- Just read as centigrade
print(t.read(nil,t.C))
-- Don't forget to release it after use
t = nil
ds18b20 = nil
package.loaded["ds18b20"]=nil
```
####Control a WS2812 based light strip
```lua
-- set the color of one LED on GPIO 2 to red
ws2812.write(4, string.char(0, 255, 0))
-- set the color of 10 LEDs on GPIO 0 to blue
ws2812.write(3, string.char(0, 0, 255):rep(10))
-- first LED green, second LED white
ws2812.write(4, string.char(255, 0, 0, 255, 255, 255))
```