Fix LFS Markdown syntax

Contributes to #2432
This commit is contained in:
Marcel Stör 2018-07-23 23:00:11 +02:00
parent a405fea474
commit 2e202796b8
2 changed files with 62 additions and 55 deletions

View File

@ -4,69 +4,76 @@
LFS is a way how to execute your Lua code out of ESP8266 flash memory so more RAM is available for variables and data structures. This way large Lua files can be run on ESP8266. There would not be enough RAM to execute such files in a "normal" (out of SPIFFS) way.
The tutorial assumes that you are able to build a nodemcu-firmware on a Windows 10 host.
The tutorial assumes that you are able to build a NodeMCU firmware on a Windows 10 host.
This is a simple step-by-step how to use the LFS feature:
1. Get and flash LFS enabled firmware
This is a simple step-by-step recipe how to use the LFS feature.
Either you get it from [NodeMCU Build](https://nodemcu-build.com/). In the section "LFS options (currently just for dev)" choose the size of the LFS partition (64 KB should be fine). SPIFFS default settings should be fine.
### Get and flash LFS enabled firmware
Another possibility is to compile own firmware and enable LFS in [user_config.h](../../app/include/user_config.h), setting `#define LUA_FLASH_STORE 0x10000`. This file includes explanation of how to configure LFS in its comments.
Get the firmware from [NodeMCU Build](https://nodemcu-build.com/). In the section "LFS options (currently just for dev)" choose the size of the LFS partition (64 KB should be fine). SPIFFS default settings should be fine.
For details see section [Selecting the firmware](###Selecting-the-firmware) of the LFS documentation.
Another possibility is to compile your own firmware and enable LFS in [user_config.h](../../app/include/user_config.h), setting `#define LUA_FLASH_STORE 0x10000`. This file includes explanations for how to configure LFS in its comments.
Flash the firmware to ESP8266.
For details see section [Selecting the firmware](#selecting-the-firmware) of the LFS documentation below.
2. Select Lua files to be run from LFS
[Flash the firmware](flash.md) to ESP8266.
The easest way is to maintain Lua files of your project in its own directory tree on your host. Project files will be compiled by `luac.cross` to build the LFS image in next step.
### Select Lua files to be run from LFS
Nice example is to run telnet and ftp client from LFS. In order to do this put the following files in 1 directory:
* [lua_examples/lfs/_init.lua](../../lua_examples/lfs/_init.lua)
* [lua_examples/lfs/dummy_strings.lua](../../lua_examples/lfs/dummy_strings.lua)
* [lua_examples/telnet/telnet.lua](../../lua_examples/telnet/telnet.lua)
* [lua_modules/ftp/ftpserver.lua](../../lua_modules/ftp/ftpserver.lua)
The easiest way is to maintain Lua files of your project in its own directory tree on your host. Project files will be compiled by `luac.cross` to build the LFS image in next step.
3. Build the LFS image
A nice example is to run Telnet and FTP servers from LFS. In order to do this put the following files in 1 directory:
Windows 10 users can use the Windows Subsystem for Linux. From the directory with Lua files from the previous section run `bash` and execute the command (adjust the path as needed):
```bash
/mnt/c/GitHub/nodemcu-firmware/luac.cross -f *.lua
```
or the following command which includes all Lua files except `init.lua` into LFS image can be used (`init.lua` needs to be in SPIFFS so it does not make sense to include it in the LFS image)
```bash
/mnt/c/GitHub/nodemcu-firmware/luac.cross -f `find *.lua -not -name 'init.lua'`
```
As a result the `luac.out` file is created.
* [lua_examples/lfs/_init.lua](../../lua_examples/lfs/_init.lua)
* [lua_examples/lfs/dummy_strings.lua](../../lua_examples/lfs/dummy_strings.lua)
* [lua_examples/telnet/telnet.lua](../../lua_examples/telnet/telnet.lua)
* [lua_modules/ftp/ftpserver.lua](../../lua_modules/ftp/ftpserver.lua)
4. Upload the LFS image
### Build the LFS image
Now it's time to upload the generate LFS image file (`luac.out`) as a normal SPIFFS file. Several tools can be used to upload the files from host to SPIFFS.
Windows 10 users can use the Windows Subsystem for Linux. From the directory with Lua files from the previous section run `bash` and execute the command (adjust the path as needed):
One way is to use the [ESPlorer](https://github.com/4refr0nt/ESPlorer) tool, button "Upload...".
```bash
/mnt/c/GitHub/nodemcu-firmware/luac.cross -f *.lua
```
5. Flash the LFS image to LFS partition
Or the following command which includes all Lua files except `init.lua` (`init.lua` needs to be in SPIFFS so it does not make sense to include it in the LFS image)
Run the following command on ESP
```Lua
node.flashreload("luac.out")
```
The firmware will reboot the ESP8266 and modules will be available after reboot.
```bash
/mnt/c/GitHub/nodemcu-firmware/luac.cross -f `find *.lua -not -name 'init.lua'`
```
6. Adjust the `init.lua` file
As a result the `luac.out` file is created.
`init.lua` is the file that is first executed by the NodeMCU firmware. Usually it setups the wifi connection and executes the main Lua file.
### Upload the LFS image
Add the following lines:
Now upload the generate LFS image file (`luac.out`) as a normal SPIFFS file. Several tools can be used to upload the files from host to SPIFFS.
```Lua
-- Execute the LFS init
node.flashindex("_init")()
-- Start telnet server
require("telnet"):open()
-- Start ftp serer
require("ftpserver").createServer('user', 'password')
```
One way is to use the [ESPlorer](https://github.com/4refr0nt/ESPlorer) tool, button "Upload...".
### Flash the LFS image to LFS partition
Run the following command on ESP
```lua
node.flashreload("luac.out")
```
The firmware will reboot the ESP8266 and modules will be available after reboot.
### Adjust the `init.lua` file
`init.lua` is the file that is first executed by the NodeMCU firmware. Usually it setups the wifi connection and executes the main Lua file.
Add the following lines:
```lua
-- Execute the LFS init
node.flashindex("_init")()
-- Start Telnet server
require("telnet"):open()
-- Start FTP serer
require("ftpserver").createServer('user', 'password')
```
## Background

View File

@ -33,8 +33,8 @@ pages:
- Whitepapers:
- Filesystem on SD card: 'en/sdcard.md'
- Internal filesystem: 'en/spiffs.md'
- Lua Compact Debug(LCD): 'en/lcd.md'
- Lua Flash Store(LFS): 'en/lfs.md'
- Lua Compact Debug (LCD): 'en/lcd.md'
- Lua Flash Store (LFS): 'en/lfs.md'
- Modules:
- 'adc': 'en/modules/adc.md'
- 'ads1115' : 'en/modules/ads1115.md'