mirror of
https://github.com/jerryscript-project/jerryscript.git
synced 2025-12-15 16:29:21 +00:00
* Rename modified fdlibm to jerry-libm
* Move third-party/fdlibm to jerry-libm
* Rename original fdlibm.h to jerry-libm-internal.h
* And remove it from the public headers.
* Rename jerry-libm's public header to math.h
* This also makes jerry-core sources include `<math.h>`. Therefore,
should anyone want to use a different libm implementation with
jerry, it becomes possible. (The same way as we provide a minimal
libc with standard headers, but should it be insufficient or
conflicting for someone, it can be replaced.)
* Drop `s_` prefix from jerry-libm sources
* The original fdlibm implementation had various prefixes (e.g., `k_`
for sources of kernel routines, and `w_` for wrapper routines), but
after the specialization of fdlibm to jerry, only `s_` remained.
Since it does not encode anything anymore, it can be dropped.
* Stylistic edits to jerry-libm's CMakeLists
* Align project name with other CMakeLists in the code base
* Move Jerry-LibM under Apache License
* Using the same approach as was used by linux-wireless when ath5k
driver license needed clarification. Solution was proposed by SFLC.
External mail for future reference: http://lwn.net/Articles/247806/
* Tests & checks
* Remove FD from the name of libm unit test-related files
* Make vera++ and cppcheck check jerry-libm
* Targets
* Speculative update of targets to use jerry-libm
JerryScript-DCO-1.0-Signed-off-by: Akos Kiss akiss@inf.u-szeged.hu
179 lines
3.8 KiB
Markdown
179 lines
3.8 KiB
Markdown
### About
|
|
|
|
This folder contains files to run JerryScript on NuttX with
|
|
[STM32F4-Discovery with BB](http://www.st.com/web/en/catalog/tools/FM116/SC959/SS1532/LN1199/PF255417)
|
|
|
|
|
|
### How to build
|
|
|
|
#### 1. Preface
|
|
|
|
1, Directory structure
|
|
|
|
Assume `harmony` as the root folder to the projects to build.
|
|
The folder tree related would look like this.
|
|
|
|
```
|
|
harmony
|
|
+ jerryscript
|
|
| + targets
|
|
| + nuttx-stm32f4
|
|
+ nuttx
|
|
| + nuttx
|
|
| + lib
|
|
+ st-link
|
|
```
|
|
|
|
|
|
2, Target board
|
|
|
|
Assume [STM32F4-Discovery with BB](http://www.st.com/web/en/catalog/tools/FM116/SC959/SS1532/LN1199/PF255417)
|
|
as the target board.
|
|
|
|
|
|
3, Micro SD-Card memory for Script source files
|
|
|
|
|
|
#### 2. Prepare NuttX
|
|
|
|
Follow [this](https://bitbucket.org/seanshpark/nuttx/wiki/Home) page to get
|
|
NuttX source and do the first build. When it stops with and error,
|
|
change default project from `IoT.js` to `JerryScript` as follows;
|
|
|
|
2-1) run menuconfig
|
|
```
|
|
# assume you are in nuttx folder where .config exist
|
|
make menuconfig
|
|
```
|
|
2-2) Select `Application Configuration` --> `Interpreters`
|
|
|
|
2-3) Check `[*] JerryScript interpreter` (Move cursor to the line and press `Space`)
|
|
|
|
2-4) `< Exit >` once on the bottom of the sceen (Press `Right arrow` and `Enter`)
|
|
|
|
2-5) Select `System Libraries and NSH Add-Ons`
|
|
|
|
2-6) Un-Check `[ ] iotjs program` (Move cursor to the line and press `Space`)
|
|
|
|
2-7) `< Exit >` till `menuconfig` ends. Save new configugation when asked.
|
|
|
|
2-7) `make` again
|
|
```
|
|
make
|
|
```
|
|
|
|
It'll show the last error but it's ok. Nows the time to build JerryScript.
|
|
|
|
|
|
#### 3. Build JerryScript for NuttX
|
|
|
|
```
|
|
# assume you are in harmony folder
|
|
cd jerryscript
|
|
make -f ./targets/nuttx-stm32f4/Makefile.nuttx
|
|
```
|
|
|
|
If you have NuttX at another path than described above, you can give the
|
|
absolute path with `NUTTX` variable , for example,
|
|
```
|
|
NUTTX=/home/user/work/nuttx make -f ./targets/nuttx-stm32f4/Makefile.nuttx
|
|
```
|
|
|
|
Make will copy three library files to `nuttx/nuttx/lib` folder
|
|
```
|
|
libjerryentry.a
|
|
libjerrycore.a
|
|
libjerrylibm.a
|
|
```
|
|
|
|
In NuttX, if you run `make clean`, above library files are also removed so you
|
|
may have to build JerryScript again.
|
|
|
|
#### 4. Continue build NuttX
|
|
|
|
```
|
|
# asssume you are in harmony folder
|
|
cd nuttx/nuttx
|
|
make
|
|
```
|
|
|
|
|
|
#### 5. Flashing
|
|
|
|
Connect Mini-USB for power supply and connect Micro-USB for `NSH` console.
|
|
|
|
Please refer [this](https://github.com/Samsung/iotjs/wiki/Build-for-NuttX#prepare-flashing-to-target-board)
|
|
link to prepare `stlink` utility.
|
|
|
|
|
|
To flash with `Makefile.nuttx`,
|
|
```
|
|
# assume you are in jerryscript folder
|
|
make -f ./targets/nuttx-stm32f4/Makefile.nuttx flash
|
|
```
|
|
|
|
#### 6. Cleaning
|
|
|
|
To clean the build result,
|
|
```
|
|
make -f ./targets/nuttx-stm32f4/Makefile.nuttx clean
|
|
```
|
|
|
|
|
|
### Running JerryScript
|
|
|
|
Prepare a micro SD-card and prepare `hello.js` like this in the root directory of SD-card.
|
|
|
|
```
|
|
print("Hello JerryScript!");
|
|
```
|
|
|
|
Power Off(unplug both USB cables), plug the memory card to BB, and power on again.
|
|
|
|
You can use `minicom` for terminal program, or any other you may like, but match
|
|
baud rate to `115200`.
|
|
|
|
```
|
|
minicom --device=/dev/ttyACM0 --baud=115200
|
|
```
|
|
|
|
|
|
You may have to press `RESET` on the board and press `Enter` keys on the console
|
|
several times to make `nsh` prompt to appear.
|
|
|
|
If the prompt shows like this,
|
|
```
|
|
NuttShell (NSH)
|
|
nsh>
|
|
nsh>
|
|
nsh>
|
|
```
|
|
please set `Add Carriage Ret` option by `CTRL-A` > `Z` > `U` at the console,
|
|
if you're using `minicom`.
|
|
|
|
|
|
Run `jerryscript` with `hello.js`
|
|
|
|
```
|
|
NuttShell (NSH)
|
|
nsh>
|
|
nsh>
|
|
nsh> jerryscript /mnt/sdcard/hello.js
|
|
PARAM 1 : [/mnt/sdcard/hello.js]
|
|
Hello JerryScript!
|
|
```
|
|
|
|
Please give absolute path of the script file or may get an error like this.
|
|
```
|
|
nsh> cd /mnt/sdcard
|
|
nsh> jerryscript ./hello.js
|
|
PARAM 1 : [./hello.js]
|
|
Failed to fopen [./hello.js]
|
|
JERRY_STANDALONE_EXIT_CODE_FAIL
|
|
nsh>
|
|
nsh>
|
|
nsh> jerryscript /mnt/sdcard/hello.js
|
|
PARAM 1 : [/mnt/sdcard/hello.js]
|
|
Hello JerryScript!
|
|
```
|