mirror of
https://github.com/oliverschmidt/contiki.git
synced 2025-01-11 19:29:50 +00:00
47 lines
1.5 KiB
Plaintext
47 lines
1.5 KiB
Plaintext
|
ELFloader and shell command 'exec' example for Sky platform
|
||
|
-----------------------------------------------------------
|
||
|
|
||
|
Compiles the Contiki hello-world application as a Contiki executable (.ce).
|
||
|
The Contiki executable is then uploaded to the Sky platform via serial, and
|
||
|
is stored in the filesystem.
|
||
|
Finally, the executable is loaded via the shell command 'exec'.
|
||
|
|
||
|
NOTE:
|
||
|
You may have to reduce the ELF loader memory usage (/platform/sky/contiki-conf.h).
|
||
|
Since hello-world uses very little memory:
|
||
|
#define ELFLOADER_CONF_DATAMEMORY_SIZE 0x100
|
||
|
#define ELFLOADER_CONF_TEXTMEMORY_SIZE 0x100
|
||
|
|
||
|
|
||
|
1. Upload Sky shell with 'exec' command and symbols (requires several recompilations to generate correct symbols):
|
||
|
> make sky-shell-exec.sky
|
||
|
> make sky-shell-exec.sky CORE=sky-shell-exec.sky
|
||
|
> make sky-shell-exec.upload CORE=sky-shell-exec.sky
|
||
|
|
||
|
|
||
|
2. Verify access to the shell and the filesystem:
|
||
|
> make login
|
||
|
SHELL> echo hello shell
|
||
|
SHELL> echo test | write mytest.txt
|
||
|
SHELL> ls
|
||
|
SHELL> read mytest.txt
|
||
|
[CTRL-C] to exit the shell
|
||
|
|
||
|
|
||
|
3. Upload Contiki executable hello-world.ce:
|
||
|
> make upload-executable
|
||
|
[CTRL-C] to exit the shell when the entire file has been uploaded (after ~30 sec)
|
||
|
|
||
|
|
||
|
4. Verify that hello-world.ce exists in CFS:
|
||
|
> make login
|
||
|
SHELL> ls
|
||
|
SHELL> read hello-world.ce | size
|
||
|
The last command output should equal the size of hello-world.ce in this directory!
|
||
|
|
||
|
|
||
|
5. Load and start hello world:
|
||
|
SHELL> exec hello-world.ce
|
||
|
The program should now start: the output 'Hello, World' appears.
|
||
|
|