Separate targets into os and baremetal-sdk parts (#4842)
JerryScript-DCO-1.0-Signed-off-by: Roland Takacs roland.takacs@h-lab.eu
This commit is contained in:
@@ -0,0 +1,9 @@
|
||||
mbed-os
|
||||
mbed-events
|
||||
.build
|
||||
.mbed
|
||||
.temp/
|
||||
mbed_settings.py
|
||||
js/pins.js
|
||||
source/pins.cpp
|
||||
source/jerry-targetjs.h
|
||||
@@ -0,0 +1,94 @@
|
||||
# Copyright JS Foundation and other contributors, http://js.foundation
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
|
||||
# USAGE:
|
||||
# specify the board using the command line:
|
||||
# make BOARD=[mbed board name]
|
||||
|
||||
BOARD=$(subst [mbed] ,,$(shell mbed target))
|
||||
HEAPSIZE=16
|
||||
|
||||
DEBUG?=0
|
||||
NO_JS?=0
|
||||
MBED_VERBOSE?=0
|
||||
|
||||
MBED_CLI_FLAGS=-j0 --source . --source ../../../
|
||||
|
||||
EXTRA_SRC=
|
||||
|
||||
ifneq ($(EXTRA_SRC),)
|
||||
EXTRA_SRC_MOD=--source $(subst :, --source ,$(EXTRA_SRC))
|
||||
MBED_CLI_FLAGS += $(EXTRA_SRC_MOD)
|
||||
endif
|
||||
|
||||
EXTERN_BUILD_DIR=
|
||||
|
||||
ifneq ($(EXTERN_BUILD_DIR),)
|
||||
MBED_CLI_FLAGS += --build $(EXTERN_BUILD_DIR)
|
||||
endif
|
||||
|
||||
ifeq ($(DEBUG), 1)
|
||||
MBED_CLI_FLAGS += --profile ./mbed-os/tools/profiles/debug.json
|
||||
endif
|
||||
|
||||
ifeq ($(MBED_VERBOSE), 1)
|
||||
MBED_CLI_FLAGS += -v
|
||||
else ifeq ($(MBED_VERBOSE), 2)
|
||||
MBED_CLI_FLAGS += -vv
|
||||
endif
|
||||
|
||||
MBED_CLI_FLAGS += -D "JERRY_GLOBAL_HEAP_SIZE=$(HEAPSIZE)"
|
||||
MBED_CLI_FLAGS += -t GCC_ARM
|
||||
|
||||
.PHONY: all js2c getlibs rebuild library
|
||||
all: source/jerry-targetjs.h source/pins.cpp .mbed ../../../.mbedignore
|
||||
mbed target $(BOARD)
|
||||
mbed compile $(MBED_CLI_FLAGS)
|
||||
|
||||
library: .mbed ../../../.mbedignore
|
||||
# delete encoded js code if it exists
|
||||
rm -f source/jerry-targetjs.h
|
||||
mbed target $(BOARD)
|
||||
mbed compile $(MBED_CLI_FLAGS) --library
|
||||
|
||||
clean:
|
||||
rm -rf ./BUILD/$(BOARD)
|
||||
|
||||
js2c: js/main.js js/flash_leds.js
|
||||
python ../../../tools/js2c.py --ignore pins.js
|
||||
|
||||
source/pins.cpp:
|
||||
python tools/generate_pins.py ${BOARD}
|
||||
|
||||
ifeq ($(NO_JS),0)
|
||||
source/jerry-targetjs.h: js2c
|
||||
else
|
||||
source/jerry-targetjs.h: ;
|
||||
endif
|
||||
|
||||
getlibs: .mbed
|
||||
|
||||
.mbed:
|
||||
echo 'ROOT=.' > .mbed
|
||||
mbed config root .
|
||||
mbed toolchain GCC_ARM
|
||||
mbed target $(BOARD)
|
||||
mbed deploy
|
||||
|
||||
../../../.mbedignore:
|
||||
ifeq ($(OS),Windows_NT)
|
||||
copy template-mbedignore.txt ..\..\..\.mbedignore
|
||||
else
|
||||
cp ./template-mbedignore.txt ../../../.mbedignore
|
||||
endif
|
||||
@@ -0,0 +1,40 @@
|
||||
# Copyright JS Foundation and other contributors, http://js.foundation
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
|
||||
|
||||
# Default target for running the build test outside the Travis CI environment.
|
||||
all:
|
||||
$(MAKE) install
|
||||
$(MAKE) script
|
||||
|
||||
|
||||
## Targets for installing build dependencies of the Mbed OS 5 JerryScript target.
|
||||
|
||||
# Deploy Mbed and install Mbed Python dependencies.
|
||||
install:
|
||||
pip install mbed-cli
|
||||
cd targets/os/mbedos5 && mbed deploy
|
||||
pip install idna==2.5 # FIXME: workaround
|
||||
pip install -r targets/os/mbedos5/mbed-os/requirements.txt
|
||||
pip install -r targets/os/mbedos5/tools/requirements.txt
|
||||
|
||||
|
||||
## Targets for building Mbed OS 5 with JerryScript.
|
||||
|
||||
# Build the firmware (Mbed OS 5 with JerryScript).
|
||||
script:
|
||||
# HACK: `EXTRA_SRC[_MOD]` are abused to pass `--library` to `mbed compile` in the `all` make target that builds an app
|
||||
# HACK: this is needed because the Mbed OS 5 target code does not contain any `main` function, so the `all` make target does not link
|
||||
# HACK: but the `library` make target does not build either because the launcher sources require `jerry-targetjs.h` that are explicitly not generated for libraries
|
||||
$(MAKE) -C targets/os/mbedos5 BOARD=K64F EXTRA_SRC=dummy EXTRA_SRC_MOD=--library
|
||||
@@ -0,0 +1,74 @@
|
||||
# JerryScript with mbed OS 5
|
||||
|
||||
TL;DR? jump straight to [quickstart](#quick-start)
|
||||
|
||||
## Introduction
|
||||
|
||||
This directory contains the necessary code to build JerryScript for devices
|
||||
capable of running mbed OS 5. It has been tested with the following boards
|
||||
so far:
|
||||
|
||||
- [Nordic Semiconductor NRF52 Development Kit](https://developer.mbed.org/platforms/Nordic-nRF52-DK/)
|
||||
- [NXP Freedom K64F](https://developer.mbed.org/platforms/FRDM-K64F/)
|
||||
- [STM NUCLEO F401RE](https://developer.mbed.org/platforms/ST-Nucleo-F401RE/)
|
||||
- [Silicon Labs EFM32 Giant Gecko](https://developer.mbed.org/platforms/EFM32-Giant-Gecko/)
|
||||
|
||||
## Features
|
||||
|
||||
### Peripheral Drivers
|
||||
|
||||
Peripheral Drivers are intended as a 1-to-1 mapping to mbed C++ APIs, with a few
|
||||
differences (due to differences between JavaScript and C++ like lack of operator
|
||||
overloading).
|
||||
|
||||
- [DigitalOut](https://docs.mbed.com/docs/mbed-os-api-reference/en/5.1/APIs/io/DigitalOut/)
|
||||
- [InterruptIn](https://docs.mbed.com/docs/mbed-os-api-reference/en/5.1/APIs/io/InterruptIn/)
|
||||
- [I2C](https://docs.mbed.com/docs/mbed-os-api-reference/en/5.1/APIs/interfaces/digital/I2C/)
|
||||
- setInterval and setTimeout using [mbed-event](https://github.com/ARMmbed/mbed-events)
|
||||
|
||||
## Dependencies
|
||||
|
||||
### mbed CLI
|
||||
|
||||
mbed CLI is used as the build tool for mbed OS 5. You can find out how to install
|
||||
it in the [official documentation](https://docs.mbed.com/docs/mbed-os-handbook/en/5.1/dev_tools/cli/#installing-mbed-cli).
|
||||
|
||||
### arm-none-eabi-gcc
|
||||
|
||||
arm-none-eabi-gcc is the only currently tested compiler for jerryscript on mbed,
|
||||
and instructions for building can be found as part of the mbed-cli installation
|
||||
instructions above.
|
||||
|
||||
### make
|
||||
|
||||
make is used to automate the process of fetching dependencies, and making sure that
|
||||
mbed-cli is called with the correct arguments.
|
||||
|
||||
### nodejs
|
||||
|
||||
npm is used to install the dependencies in the local node_modules folder.
|
||||
|
||||
### gulp
|
||||
|
||||
gulp is used to automate tasks, like cloning repositories or generate source files.
|
||||
If you create an own project, for more info see [mbed-js-gulp](https://github.com/ARMmbed/mbed-js-gulp).
|
||||
|
||||
### (optional) jshint
|
||||
|
||||
jshint is used to statically check your JavaScript code, as part of the build process.
|
||||
This ensures that pins you are using in your code are available on your chosen target
|
||||
platform.
|
||||
|
||||
## Quick Start
|
||||
|
||||
Once you have all of your dependencies installed, you can build the example project as follows:
|
||||
|
||||
```bash
|
||||
git clone https://github.com/ARMmbed/mbed-js-example
|
||||
cd mbed-js-example
|
||||
npm install
|
||||
gulp --target=YOUR_TARGET_NAME
|
||||
```
|
||||
|
||||
The produced file (in build/out/YOUR_TARGET_NAME) can then be uploaded to your board, and will
|
||||
run when you press reset.
|
||||
@@ -0,0 +1,22 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#ifndef _JERRYSCRIPT_MBED_DRIVERS_ANALOGIN_H
|
||||
#define _JERRYSCRIPT_MBED_DRIVERS_ANALOGIN_H
|
||||
|
||||
#include "jerryscript-mbed-library-registry/wrap_tools.h"
|
||||
|
||||
DECLARE_CLASS_CONSTRUCTOR(AnalogIn);
|
||||
|
||||
#endif // _JERRYSCRIPT_MBED_DRIVERS_ANALOGIN_H
|
||||
@@ -0,0 +1,22 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#ifndef _JERRYSCRIPT_MBED_DRIVERS_DIGITALOUT_H
|
||||
#define _JERRYSCRIPT_MBED_DRIVERS_DIGITALOUT_H
|
||||
|
||||
#include "jerryscript-mbed-library-registry/wrap_tools.h"
|
||||
|
||||
DECLARE_CLASS_CONSTRUCTOR(DigitalOut);
|
||||
|
||||
#endif // _JERRYSCRIPT_MBED_DRIVERS_DIGITALOUT_H
|
||||
@@ -0,0 +1,22 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#ifndef _JERRYSCRIPT_MBED_DRIVERS_I2C_H
|
||||
#define _JERRYSCRIPT_MBED_DRIVERS_I2C_H
|
||||
|
||||
#include "jerryscript-mbed-library-registry/wrap_tools.h"
|
||||
|
||||
DECLARE_CLASS_CONSTRUCTOR(I2C);
|
||||
|
||||
#endif // _JERRYSCRIPT_MBED_DRIVERS_I2C_H
|
||||
@@ -0,0 +1,22 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#ifndef _JERRYSCRIPT_MBED_DRIVERS_INTERRUPTIN_H
|
||||
#define _JERRYSCRIPT_MBED_DRIVERS_INTERRUPTIN_H
|
||||
|
||||
#include "jerryscript-mbed-library-registry/wrap_tools.h"
|
||||
|
||||
DECLARE_CLASS_CONSTRUCTOR(InterruptIn);
|
||||
|
||||
#endif // _JERRYSCRIPT_MBED_DRIVERS_INTERRUPTIN_H
|
||||
@@ -0,0 +1,22 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#ifndef _JERRYSCRIPT_MBED_DRIVERS_PWMOUT_H
|
||||
#define _JERRYSCRIPT_MBED_DRIVERS_PWMOUT_H
|
||||
|
||||
#include "jerryscript-mbed-library-registry/wrap_tools.h"
|
||||
|
||||
DECLARE_CLASS_CONSTRUCTOR(PwmOut);
|
||||
|
||||
#endif // _JERRYSCRIPT_MBED_DRIVERS_PWMOUT_H
|
||||
@@ -0,0 +1,42 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#ifndef _JERRYSCRIPT_MBED_DRIVERS_LIB_DRIVERS_H
|
||||
#define _JERRYSCRIPT_MBED_DRIVERS_LIB_DRIVERS_H
|
||||
|
||||
#include "jerryscript-ext/handler.h"
|
||||
#include "jerryscript-mbed-drivers/InterruptIn-js.h"
|
||||
#include "jerryscript-mbed-drivers/DigitalOut-js.h"
|
||||
#include "jerryscript-mbed-drivers/setInterval-js.h"
|
||||
#include "jerryscript-mbed-drivers/setTimeout-js.h"
|
||||
#include "jerryscript-mbed-drivers/I2C-js.h"
|
||||
#include "jerryscript-mbed-drivers/AnalogIn-js.h"
|
||||
#include "jerryscript-mbed-drivers/PwmOut-js.h"
|
||||
|
||||
DECLARE_JS_WRAPPER_REGISTRATION (base) {
|
||||
REGISTER_GLOBAL_FUNCTION_WITH_HANDLER(assert, jerryx_handler_assert);
|
||||
REGISTER_GLOBAL_FUNCTION_WITH_HANDLER(gc, jerryx_handler_gc);
|
||||
REGISTER_GLOBAL_FUNCTION_WITH_HANDLER(print, jerryx_handler_print);
|
||||
REGISTER_GLOBAL_FUNCTION(setInterval);
|
||||
REGISTER_GLOBAL_FUNCTION(setTimeout);
|
||||
REGISTER_GLOBAL_FUNCTION(clearInterval);
|
||||
REGISTER_GLOBAL_FUNCTION(clearTimeout);
|
||||
REGISTER_CLASS_CONSTRUCTOR(DigitalOut);
|
||||
REGISTER_CLASS_CONSTRUCTOR(I2C);
|
||||
REGISTER_CLASS_CONSTRUCTOR(InterruptIn);
|
||||
REGISTER_CLASS_CONSTRUCTOR(AnalogIn);
|
||||
REGISTER_CLASS_CONSTRUCTOR(PwmOut);
|
||||
}
|
||||
|
||||
#endif // _JERRYSCRIPT_MBED_DRIVERS_LIB_DRIVERS_H
|
||||
@@ -0,0 +1,23 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#ifndef _JERRYSCRIPT_MBED_DRIVERS_SET_INTERVAL_H
|
||||
#define _JERRYSCRIPT_MBED_DRIVERS_SET_INTERVAL_H
|
||||
|
||||
#include "jerryscript-mbed-library-registry/wrap_tools.h"
|
||||
|
||||
DECLARE_GLOBAL_FUNCTION(setInterval);
|
||||
DECLARE_GLOBAL_FUNCTION(clearInterval);
|
||||
|
||||
#endif // _JERRYSCRIPT_MBED_DRIVERS_SET_INTERVAL_H
|
||||
@@ -0,0 +1,23 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#ifndef _JERRYSCRIPT_MBED_DRIVERS_SET_TIMEOUT_H
|
||||
#define _JERRYSCRIPT_MBED_DRIVERS_SET_TIMEOUT_H
|
||||
|
||||
#include "jerryscript-mbed-library-registry/wrap_tools.h"
|
||||
|
||||
DECLARE_GLOBAL_FUNCTION(setTimeout);
|
||||
DECLARE_GLOBAL_FUNCTION(clearTimeout);
|
||||
|
||||
#endif // _JERRYSCRIPT_MBED_DRIVERS_SET_TIMEOUT_H
|
||||
@@ -0,0 +1,114 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#include "jerryscript-mbed-library-registry/wrap_tools.h"
|
||||
#include "jerryscript-mbed-util/logging.h"
|
||||
#include "mbed.h"
|
||||
|
||||
/**
|
||||
* AnalogIn#destructor
|
||||
*
|
||||
* Called if/when the AnalogIn is GC'ed.
|
||||
*/
|
||||
void
|
||||
NAME_FOR_CLASS_NATIVE_DESTRUCTOR (AnalogIn) (void* void_ptr, jerry_object_native_info_t* info_p)
|
||||
{
|
||||
(void) info_p;
|
||||
delete static_cast<AnalogIn*> (void_ptr);
|
||||
}
|
||||
|
||||
/**
|
||||
* Type infomation of the native AnalogIn pointer
|
||||
*
|
||||
* Set AnalogIn#destructor as the free callback.
|
||||
*/
|
||||
static const jerry_object_native_info_t native_obj_type_info = { .free_cb =
|
||||
NAME_FOR_CLASS_NATIVE_DESTRUCTOR (AnalogIn) };
|
||||
|
||||
/**
|
||||
* AnalogIn#read (native JavaScript method)
|
||||
*
|
||||
* Read the input voltage, represented as a float in the range [0.0, 1.0]
|
||||
*
|
||||
* @returns A floating-point value representing the current input voltage, measured as a percentage
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (AnalogIn, read)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (AnalogIn, read, (args_count == 0));
|
||||
|
||||
// Extract native AnalogIn pointer
|
||||
void* void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native AnalogIn pointer");
|
||||
}
|
||||
|
||||
AnalogIn* native_ptr = static_cast<AnalogIn*> (void_ptr);
|
||||
|
||||
float result = native_ptr->read ();
|
||||
return jerry_number (result);
|
||||
}
|
||||
|
||||
/**
|
||||
* AnalogIn#read_u16 (native JavaScript method)
|
||||
*
|
||||
* Read the input voltage, represented as an unsigned short in the range [0x0, 0xFFFF]
|
||||
*
|
||||
* @returns 16-bit unsigned short representing the current input voltage, normalised to a 16-bit value
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (AnalogIn, read_u16)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (AnalogIn, read_u16, (args_count == 0));
|
||||
|
||||
// Extract native AnalogIn pointer
|
||||
void* void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native AnalogIn pointer");
|
||||
}
|
||||
|
||||
AnalogIn* native_ptr = static_cast<AnalogIn*> (void_ptr);
|
||||
|
||||
uint16_t result = native_ptr->read_u16 ();
|
||||
return jerry_number (result);
|
||||
}
|
||||
|
||||
/**
|
||||
* AnalogIn (native JavaScript constructor)
|
||||
*
|
||||
* @param pin_name mbed pin to connect the AnalogIn to.
|
||||
* @returns a JavaScript object representing a AnalogIn.
|
||||
*/
|
||||
DECLARE_CLASS_CONSTRUCTOR (AnalogIn)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (AnalogIn, __constructor, args_count == 1);
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (AnalogIn, __constructor, 0, number);
|
||||
|
||||
PinName pin_name = PinName (jerry_value_as_number (args[0]));
|
||||
|
||||
// create native object
|
||||
AnalogIn* native_ptr = new AnalogIn (pin_name);
|
||||
|
||||
// create the jerryscript object
|
||||
jerry_value_t js_object = jerry_object ();
|
||||
jerry_object_set_native_ptr (js_object, &native_obj_type_info, native_ptr);
|
||||
|
||||
// attach methods
|
||||
ATTACH_CLASS_FUNCTION (js_object, AnalogIn, read);
|
||||
ATTACH_CLASS_FUNCTION (js_object, AnalogIn, read_u16);
|
||||
|
||||
return js_object;
|
||||
}
|
||||
+158
@@ -0,0 +1,158 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#include "jerryscript-mbed-library-registry/wrap_tools.h"
|
||||
#include "jerryscript-mbed-util/logging.h"
|
||||
#include "mbed.h"
|
||||
|
||||
/**
|
||||
* DigitalOut#destructor
|
||||
*
|
||||
* Called if/when the DigitalOut is GC'ed.
|
||||
*/
|
||||
void
|
||||
NAME_FOR_CLASS_NATIVE_DESTRUCTOR (DigitalOut) (void* void_ptr, jerry_object_native_info_t* info_p)
|
||||
{
|
||||
(void) info_p;
|
||||
delete static_cast<DigitalOut*> (void_ptr);
|
||||
}
|
||||
|
||||
/**
|
||||
* Type infomation of the native DigitalOut pointer
|
||||
*
|
||||
* Set DigitalOut#destructor as the free callback.
|
||||
*/
|
||||
static const jerry_object_native_info_t native_obj_type_info = { .free_cb =
|
||||
NAME_FOR_CLASS_NATIVE_DESTRUCTOR (DigitalOut) };
|
||||
|
||||
/**
|
||||
* DigitalOut#write (native JavaScript method)
|
||||
*
|
||||
* Writes a binary value to a DigitalOut.
|
||||
*
|
||||
* @param value 1 or 0, specifying whether the output pin is high or low,
|
||||
* respectively
|
||||
* @returns undefined, or an error if invalid arguments are provided.
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (DigitalOut, write)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (DigitalOut, write, (args_count == 1));
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (DigitalOut, write, 0, number);
|
||||
|
||||
// Extract native DigitalOut pointer
|
||||
void* void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native DigitalOut pointer");
|
||||
}
|
||||
|
||||
DigitalOut* native_ptr = static_cast<DigitalOut*> (void_ptr);
|
||||
|
||||
int arg0 = jerry_value_as_number (args[0]);
|
||||
native_ptr->write (arg0);
|
||||
|
||||
return jerry_undefined ();
|
||||
}
|
||||
|
||||
/**
|
||||
* DigitalOut#read (native JavaScript method)
|
||||
*
|
||||
* Reads the current status of a DigitalOut
|
||||
*
|
||||
* @returns 1 if the pin is currently high, or 0 if the pin is currently low.
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (DigitalOut, read)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (DigitalOut, read, (args_count == 0));
|
||||
|
||||
// Extract native DigitalOut pointer
|
||||
void* void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native DigitalOut pointer");
|
||||
}
|
||||
|
||||
DigitalOut* native_ptr = static_cast<DigitalOut*> (void_ptr);
|
||||
|
||||
int result = native_ptr->read ();
|
||||
return jerry_number (result);
|
||||
}
|
||||
|
||||
/**
|
||||
* DigitalOut#is_connected (native JavaScript method)
|
||||
*
|
||||
* @returns 0 if the DigitalOut is set to NC, or 1 if it is connected to an
|
||||
* actual pin
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (DigitalOut, is_connected)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (DigitalOut, is_connected, (args_count == 0));
|
||||
|
||||
// Extract native DigitalOut pointer
|
||||
void* void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native DigitalOut pointer");
|
||||
}
|
||||
|
||||
DigitalOut* native_ptr = static_cast<DigitalOut*> (void_ptr);
|
||||
|
||||
int result = native_ptr->is_connected ();
|
||||
return jerry_number (result);
|
||||
}
|
||||
|
||||
/**
|
||||
* DigitalOut (native JavaScript constructor)
|
||||
*
|
||||
* @param pin_name mbed pin to connect the DigitalOut to.
|
||||
* @param value (optional) Initial value of the DigitalOut.
|
||||
* @returns a JavaScript object representing a DigitalOut.
|
||||
*/
|
||||
DECLARE_CLASS_CONSTRUCTOR (DigitalOut)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (DigitalOut, __constructor, (args_count == 1 || args_count == 2));
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (DigitalOut, __constructor, 0, number);
|
||||
CHECK_ARGUMENT_TYPE_ON_CONDITION (DigitalOut, __constructor, 1, number, (args_count == 2));
|
||||
|
||||
DigitalOut* native_ptr;
|
||||
|
||||
// Call correct overload of DigitalOut::DigitalOut depending on the
|
||||
// arguments passed.
|
||||
PinName pin_name = PinName (jerry_value_as_number (args[0]));
|
||||
|
||||
switch (args_count)
|
||||
{
|
||||
case 1:
|
||||
native_ptr = new DigitalOut (pin_name);
|
||||
break;
|
||||
case 2:
|
||||
int value = static_cast<int> (jerry_value_as_number (args[1]));
|
||||
native_ptr = new DigitalOut (pin_name, value);
|
||||
break;
|
||||
}
|
||||
|
||||
// create the jerryscript object
|
||||
jerry_value_t js_object = jerry_object ();
|
||||
jerry_object_set_native_ptr (js_object, &native_obj_type_info, native_ptr);
|
||||
|
||||
// attach methods
|
||||
ATTACH_CLASS_FUNCTION (js_object, DigitalOut, write);
|
||||
ATTACH_CLASS_FUNCTION (js_object, DigitalOut, read);
|
||||
ATTACH_CLASS_FUNCTION (js_object, DigitalOut, is_connected);
|
||||
|
||||
return js_object;
|
||||
}
|
||||
@@ -0,0 +1,327 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#include "jerryscript-mbed-drivers/I2C-js.h"
|
||||
|
||||
#include "jerryscript-mbed-library-registry/wrap_tools.h"
|
||||
#include "jerryscript-mbed-util/logging.h"
|
||||
#include "mbed.h"
|
||||
|
||||
/**
|
||||
* I2C#destructor
|
||||
*
|
||||
* Called if/when the I2C object is GC'ed.
|
||||
*/
|
||||
void
|
||||
NAME_FOR_CLASS_NATIVE_DESTRUCTOR (I2C) (void *void_ptr, jerry_object_native_info_t *info_p)
|
||||
{
|
||||
(void) info_p;
|
||||
delete static_cast<I2C *> (void_ptr);
|
||||
}
|
||||
|
||||
/**
|
||||
* Type infomation of the native I2C pointer
|
||||
*
|
||||
* Set I2C#destructor as the free callback.
|
||||
*/
|
||||
static const jerry_object_native_info_t native_obj_type_info = { .free_cb = NAME_FOR_CLASS_NATIVE_DESTRUCTOR (I2C) };
|
||||
|
||||
/**
|
||||
* I2C#frequency (native JavaScript method)
|
||||
*
|
||||
* Set the frequency of the I2C bus.
|
||||
*
|
||||
* @param frequency New I2C Frequency
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (I2C, frequency)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (I2C, frequency, (args_count == 1));
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (I2C, frequency, 0, number);
|
||||
|
||||
// Unwrap native I2C object
|
||||
void *void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native I2C pointer");
|
||||
}
|
||||
|
||||
I2C *native_ptr = static_cast<I2C *> (void_ptr);
|
||||
|
||||
int hz = jerry_value_as_number (args[0]);
|
||||
native_ptr->frequency (hz);
|
||||
|
||||
return jerry_undefined ();
|
||||
}
|
||||
|
||||
/**
|
||||
* I2C#read (native JavaScript method)
|
||||
*
|
||||
* Read data from the I2C bus.
|
||||
*
|
||||
* @overload I2C#read(int)
|
||||
* Read a single byte from the I2C bus
|
||||
*
|
||||
* @param ack indicates if the byte is to be acknowledged (1 => acknowledge)
|
||||
*
|
||||
* @returns array: Data read from the I2C bus
|
||||
*
|
||||
* @overload I2C#read(int, array, int)
|
||||
* Read a series of bytes from the I2C bus
|
||||
*
|
||||
* @param address I2C address to read from
|
||||
* @param data Array to read into
|
||||
* @param length Length of data to read
|
||||
*
|
||||
* @returns array: Data read from the I2C bus
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (I2C, read)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (I2C, read, (args_count == 1 || args_count == 3 || args_count == 4));
|
||||
|
||||
if (args_count == 1)
|
||||
{
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (I2C, read, 0, number);
|
||||
void *void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native I2C pointer");
|
||||
}
|
||||
|
||||
I2C *native_ptr = static_cast<I2C *> (void_ptr);
|
||||
|
||||
int data = jerry_value_as_number (args[0]);
|
||||
int result = native_ptr->read (data);
|
||||
|
||||
return jerry_number (result);
|
||||
}
|
||||
else
|
||||
{
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (I2C, read, 0, number);
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (I2C, read, 1, array);
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (I2C, read, 2, number);
|
||||
|
||||
CHECK_ARGUMENT_TYPE_ON_CONDITION (I2C, read, 3, boolean, (args_count == 4));
|
||||
|
||||
void *void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native I2C pointer");
|
||||
}
|
||||
|
||||
I2C *native_ptr = static_cast<I2C *> (void_ptr);
|
||||
|
||||
const uint32_t data_len = jerry_array_length (args[1]);
|
||||
|
||||
int address = jerry_value_as_number (args[0]);
|
||||
int length = jerry_value_as_number (args[2]);
|
||||
|
||||
char *data = new char[data_len];
|
||||
|
||||
bool repeated = false;
|
||||
if (args_count == 4)
|
||||
{
|
||||
repeated = jerry_value_is_true (args[3]);
|
||||
}
|
||||
|
||||
int result = native_ptr->read (address, data, length, repeated);
|
||||
|
||||
jerry_value_t out_array = jerry_array (data_len);
|
||||
|
||||
for (uint32_t i = 0; i < data_len; i++)
|
||||
{
|
||||
jerry_value_t val = jerry_number (double (data[i]));
|
||||
jerry_value_free (jerry_object_set_index (out_array, i, val));
|
||||
jerry_value_free (val);
|
||||
}
|
||||
|
||||
delete[] data;
|
||||
|
||||
if (result == 0)
|
||||
{
|
||||
// ACK
|
||||
return out_array;
|
||||
}
|
||||
else
|
||||
{
|
||||
// NACK
|
||||
const char *error_msg = "NACK received from I2C bus";
|
||||
|
||||
jerry_value_free (out_array);
|
||||
return jerry_throw_sz (JERRY_ERROR_COMMON, error_msg);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* I2C#write (native JavaScript method)
|
||||
*
|
||||
* @overload I2C#write(int)
|
||||
* Write a single byte to the I2C bus
|
||||
*
|
||||
* @param data Data byte to write to the I2C bus
|
||||
*
|
||||
* @returns 1 on success, 0 on failure
|
||||
*
|
||||
* @overload I2C#write(int, array, int, bool)
|
||||
* Write an array of data to a certain address on the I2C bus
|
||||
*
|
||||
* @param address 8-bit I2C slave address
|
||||
* @param data Array of bytes to send
|
||||
* @param length Length of data to write
|
||||
* @param repeated (optional) If true, do not send stop at end.
|
||||
*
|
||||
* @returns 0 on success, non-0 on failure
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (I2C, write)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (I2C, write, (args_count == 1 || args_count == 3 || args_count == 4));
|
||||
|
||||
if (args_count == 1)
|
||||
{
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (I2C, write, 0, number);
|
||||
|
||||
// Extract native I2C object
|
||||
void *void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native I2C pointer");
|
||||
}
|
||||
|
||||
I2C *native_ptr = static_cast<I2C *> (void_ptr);
|
||||
|
||||
// Unwrap arguments
|
||||
int data = jerry_value_as_number (args[0]);
|
||||
|
||||
int result = native_ptr->write (data);
|
||||
return jerry_number (result);
|
||||
}
|
||||
else
|
||||
{
|
||||
// 3 or 4
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (I2C, write, 0, number);
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (I2C, write, 1, array);
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (I2C, write, 2, number);
|
||||
CHECK_ARGUMENT_TYPE_ON_CONDITION (I2C, write, 3, boolean, (args_count == 4));
|
||||
|
||||
// Extract native I2C object
|
||||
void *void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr != NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native I2C pointer");
|
||||
}
|
||||
|
||||
I2C *native_ptr = static_cast<I2C *> (void_ptr);
|
||||
|
||||
// Unwrap arguments
|
||||
int address = jerry_value_as_number (args[0]);
|
||||
const uint32_t data_len = jerry_array_length (args[1]);
|
||||
int length = jerry_value_as_number (args[2]);
|
||||
bool repeated = args_count == 4 && jerry_value_is_true (args[3]);
|
||||
|
||||
// Construct data byte array
|
||||
char *data = new char[data_len];
|
||||
for (uint32_t i = 0; i < data_len; i++)
|
||||
{
|
||||
data[i] = jerry_value_as_number (jerry_object_get_index (args[1], i));
|
||||
}
|
||||
|
||||
int result = native_ptr->write (address, data, length, repeated);
|
||||
|
||||
// free dynamically allocated resources
|
||||
delete[] data;
|
||||
|
||||
return jerry_number (result);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* I2C#start (native JavaScript method)
|
||||
*
|
||||
* Creates a start condition on the I2C bus.
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (I2C, start)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (I2C, start, (args_count == 0));
|
||||
|
||||
// Extract native I2C object
|
||||
void *void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native I2C pointer");
|
||||
}
|
||||
|
||||
I2C *native_ptr = static_cast<I2C *> (void_ptr);
|
||||
|
||||
native_ptr->start ();
|
||||
return jerry_undefined ();
|
||||
}
|
||||
|
||||
/**
|
||||
* I2C#stop (native JavaScript method)
|
||||
*
|
||||
* Creates a stop condition on the I2C bus.
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (I2C, stop)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (I2C, stop, (args_count == 0));
|
||||
|
||||
// Extract native I2C object
|
||||
void *void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native I2C pointer");
|
||||
}
|
||||
|
||||
I2C *native_ptr = static_cast<I2C *> (void_ptr);
|
||||
|
||||
native_ptr->stop ();
|
||||
return jerry_undefined ();
|
||||
}
|
||||
|
||||
/**
|
||||
* I2C (native JavaScript constructor)
|
||||
*
|
||||
* @param sda mbed pin for I2C data
|
||||
* @param scl mbed pin for I2C clock
|
||||
* @returns a JavaScript object representing the I2C bus.
|
||||
*/
|
||||
DECLARE_CLASS_CONSTRUCTOR (I2C)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (I2C, __constructor, (args_count == 2));
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (I2C, __constructor, 0, number);
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (I2C, __constructor, 1, number);
|
||||
|
||||
int sda = jerry_value_as_number (args[0]);
|
||||
int scl = jerry_value_as_number (args[1]);
|
||||
|
||||
I2C *native_ptr = new I2C ((PinName) sda, (PinName) scl);
|
||||
|
||||
jerry_value_t js_object = jerry_object ();
|
||||
jerry_object_set_native_ptr (js_object, &native_obj_type_info, native_ptr);
|
||||
|
||||
ATTACH_CLASS_FUNCTION (js_object, I2C, frequency);
|
||||
ATTACH_CLASS_FUNCTION (js_object, I2C, read);
|
||||
ATTACH_CLASS_FUNCTION (js_object, I2C, write);
|
||||
ATTACH_CLASS_FUNCTION (js_object, I2C, start);
|
||||
ATTACH_CLASS_FUNCTION (js_object, I2C, stop);
|
||||
|
||||
return js_object;
|
||||
}
|
||||
+272
@@ -0,0 +1,272 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#include "jerryscript-mbed-event-loop/EventLoop.h"
|
||||
#include "jerryscript-mbed-library-registry/wrap_tools.h"
|
||||
#include "jerryscript-mbed-util/logging.h"
|
||||
#include "mbed.h"
|
||||
|
||||
/**
|
||||
* InterruptIn#destructor
|
||||
*
|
||||
* Called if/when the InterruptIn object is GC'ed.
|
||||
*/
|
||||
void
|
||||
NAME_FOR_CLASS_NATIVE_DESTRUCTOR (InterruptIn) (void *void_ptr, jerry_object_native_info_t *info_p)
|
||||
{
|
||||
(void) info_p;
|
||||
InterruptIn *native_ptr = static_cast<InterruptIn *> (void_ptr);
|
||||
|
||||
native_ptr->rise (0);
|
||||
native_ptr->fall (0);
|
||||
delete native_ptr;
|
||||
}
|
||||
|
||||
/**
|
||||
* Type infomation of the native InterruptIn pointer
|
||||
*
|
||||
* Set InterruptIn#destructor as the free callback.
|
||||
*/
|
||||
static const jerry_object_native_info_t native_obj_type_info = { .free_cb =
|
||||
NAME_FOR_CLASS_NATIVE_DESTRUCTOR (InterruptIn) };
|
||||
|
||||
/**
|
||||
* InterruptIn#rise (native JavaScript method)
|
||||
*
|
||||
* Register a rise callback for an InterruptIn
|
||||
*
|
||||
* @param cb Callback function, or null to detach previously attached callback.
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (InterruptIn, rise)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (InterruptIn, rise, (args_count == 1));
|
||||
|
||||
// Detach the rise callback when InterruptIn::rise(null) is called
|
||||
if (jerry_value_is_null (args[0]))
|
||||
{
|
||||
void *void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native InterruptIn pointer");
|
||||
}
|
||||
|
||||
InterruptIn *native_ptr = static_cast<InterruptIn *> (void_ptr);
|
||||
|
||||
jerry_value_t property_name = jerry_string_sz ("cb_rise");
|
||||
jerry_value_t cb_func = jerry_object_get (call_info_p->this_value, property_name);
|
||||
jerry_value_free (property_name);
|
||||
|
||||
// Only drop the callback if it exists
|
||||
if (jerry_value_is_function (cb_func))
|
||||
{
|
||||
// Ensure that the EventLoop frees memory used by the callback.
|
||||
mbed::js::EventLoop::getInstance ().dropCallback (cb_func);
|
||||
}
|
||||
jerry_value_free (cb_func);
|
||||
|
||||
native_ptr->rise (0);
|
||||
|
||||
return jerry_undefined ();
|
||||
}
|
||||
|
||||
// Assuming we actually have a callback now...
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (InterruptIn, rise, 0, function);
|
||||
|
||||
void *void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native InterruptIn pointer");
|
||||
}
|
||||
|
||||
InterruptIn *native_ptr = static_cast<InterruptIn *> (void_ptr);
|
||||
|
||||
jerry_value_t f = args[0];
|
||||
|
||||
// Pass the function to EventLoop.
|
||||
mbed::Callback<void ()> cb = mbed::js::EventLoop::getInstance ().wrapFunction (f);
|
||||
native_ptr->rise (cb);
|
||||
|
||||
// Keep track of our callback internally.
|
||||
jerry_value_t property_name = jerry_string_sz ("cb_rise");
|
||||
jerry_value_free (jerry_object_set (call_info_p->this_value, property_name, f));
|
||||
jerry_value_free (property_name);
|
||||
|
||||
return jerry_undefined ();
|
||||
}
|
||||
|
||||
/**
|
||||
* InterruptIn#fall (native JavaScript method)
|
||||
*
|
||||
* Register a fall callback for an InterruptIn
|
||||
*
|
||||
* @param cb Callback function, or null to detach previously attached callback.
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (InterruptIn, fall)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (InterruptIn, fall, (args_count == 1));
|
||||
|
||||
// Detach the fall callback when InterruptIn::fall(null) is called
|
||||
if (jerry_value_is_null (args[0]))
|
||||
{
|
||||
void *void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native InterruptIn pointer");
|
||||
}
|
||||
|
||||
InterruptIn *native_ptr = static_cast<InterruptIn *> (void_ptr);
|
||||
|
||||
jerry_value_t property_name = jerry_string_sz ("cb_fall");
|
||||
jerry_value_t cb_func = jerry_object_get (call_info_p->this_value, property_name);
|
||||
jerry_value_free (property_name);
|
||||
|
||||
// Only drop the callback if it exists
|
||||
if (jerry_value_is_function (cb_func))
|
||||
{
|
||||
// Ensure that the EventLoop frees memory used by the callback.
|
||||
mbed::js::EventLoop::getInstance ().dropCallback (cb_func);
|
||||
}
|
||||
jerry_value_free (cb_func);
|
||||
|
||||
native_ptr->fall (0);
|
||||
|
||||
return jerry_undefined ();
|
||||
}
|
||||
|
||||
// Assuming we actually have a callback now...
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (InterruptIn, fall, 0, function);
|
||||
|
||||
void *void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native InterruptIn pointer");
|
||||
}
|
||||
|
||||
InterruptIn *native_ptr = static_cast<InterruptIn *> (void_ptr);
|
||||
|
||||
jerry_value_t f = args[0];
|
||||
|
||||
// Pass the function to EventLoop.
|
||||
mbed::Callback<void ()> cb = mbed::js::EventLoop::getInstance ().wrapFunction (f);
|
||||
native_ptr->fall (cb);
|
||||
|
||||
// Keep track of our callback internally.
|
||||
jerry_value_t property_name = jerry_string_sz ("cb_fall");
|
||||
jerry_value_free (jerry_object_set (call_info_p->this_value, property_name, f));
|
||||
jerry_value_free (property_name);
|
||||
|
||||
return jerry_undefined ();
|
||||
}
|
||||
|
||||
/**
|
||||
* InterruptIn#mode (native JavaScript method)
|
||||
*
|
||||
* Set the mode of the InterruptIn pin.
|
||||
*
|
||||
* @param mode PullUp, PullDown, PullNone
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (InterruptIn, mode)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (InterruptIn, mode, (args_count == 1));
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (InterruptIn, mode, 0, number);
|
||||
|
||||
void *void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native InterruptIn pointer");
|
||||
}
|
||||
|
||||
InterruptIn *native_ptr = static_cast<InterruptIn *> (void_ptr);
|
||||
|
||||
int pull = jerry_value_as_number (args[0]);
|
||||
native_ptr->mode ((PinMode) pull);
|
||||
|
||||
return jerry_undefined ();
|
||||
}
|
||||
|
||||
/**
|
||||
* InterruptIn#disable_irq (native JavaScript method)
|
||||
*
|
||||
* Disable IRQ. See InterruptIn.h in mbed-os sources for more details.
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (InterruptIn, disable_irq)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (InterruptIn, disable_irq, (args_count == 0));
|
||||
|
||||
void *void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native InterruptIn pointer");
|
||||
}
|
||||
|
||||
InterruptIn *native_ptr = static_cast<InterruptIn *> (void_ptr);
|
||||
|
||||
native_ptr->disable_irq ();
|
||||
return jerry_undefined ();
|
||||
}
|
||||
|
||||
/**
|
||||
* InterruptIn#enable_irq (native JavaScript method)
|
||||
*
|
||||
* Enable IRQ. See InterruptIn.h in mbed-os sources for more details.
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (InterruptIn, enable_irq)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (InterruptIn, enable_irq, (args_count == 0));
|
||||
|
||||
void *void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native InterruptIn pointer");
|
||||
}
|
||||
|
||||
InterruptIn *native_ptr = static_cast<InterruptIn *> (void_ptr);
|
||||
|
||||
native_ptr->enable_irq ();
|
||||
return jerry_undefined ();
|
||||
}
|
||||
|
||||
/**
|
||||
* InterruptIn (native JavaScript constructor)
|
||||
*
|
||||
* @param pin PinName
|
||||
*
|
||||
* @returns JavaScript object wrapping InterruptIn native object
|
||||
*/
|
||||
DECLARE_CLASS_CONSTRUCTOR (InterruptIn)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (InterruptIn, __constructor, (args_count == 1));
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (InterruptIn, __constructor, 0, number);
|
||||
int pin = jerry_value_as_number (args[0]);
|
||||
|
||||
InterruptIn *native_ptr = new InterruptIn ((PinName) pin);
|
||||
jerry_value_t js_object = jerry_object ();
|
||||
|
||||
jerry_object_set_native_ptr (js_object, &native_obj_type_info, native_ptr);
|
||||
|
||||
ATTACH_CLASS_FUNCTION (js_object, InterruptIn, rise);
|
||||
ATTACH_CLASS_FUNCTION (js_object, InterruptIn, fall);
|
||||
ATTACH_CLASS_FUNCTION (js_object, InterruptIn, mode);
|
||||
ATTACH_CLASS_FUNCTION (js_object, InterruptIn, enable_irq);
|
||||
ATTACH_CLASS_FUNCTION (js_object, InterruptIn, disable_irq);
|
||||
|
||||
return js_object;
|
||||
}
|
||||
@@ -0,0 +1,292 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#include "jerryscript-mbed-library-registry/wrap_tools.h"
|
||||
#include "jerryscript-mbed-util/logging.h"
|
||||
#include "mbed.h"
|
||||
|
||||
/**
|
||||
* PwmOut#destructor
|
||||
*
|
||||
* Called if/when the PwmOut is GC'ed.
|
||||
*/
|
||||
void
|
||||
NAME_FOR_CLASS_NATIVE_DESTRUCTOR (PwmOut) (void* void_ptr, jerry_object_native_info_t* info_p)
|
||||
{
|
||||
(void) info_p;
|
||||
delete static_cast<PwmOut*> (void_ptr);
|
||||
}
|
||||
|
||||
/**
|
||||
* Type infomation of the native PwmOut pointer
|
||||
*
|
||||
* Set PwmOut#destructor as the free callback.
|
||||
*/
|
||||
static const jerry_object_native_info_t native_obj_type_info = { .free_cb = NAME_FOR_CLASS_NATIVE_DESTRUCTOR (PwmOut) };
|
||||
|
||||
/**
|
||||
* PwmOut#write (native JavaScript method)
|
||||
*
|
||||
* Set the ouput duty-cycle, specified as a percentage (float)
|
||||
*
|
||||
* @param value A floating-point value representing the output duty-cycle,
|
||||
* specified as a percentage. The value should lie between
|
||||
* 0.0 (representing on 0%) and 1.0 (representing on 100%).
|
||||
* Values outside this range will be saturated to 0.0f or 1.0f
|
||||
* @returns undefined
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (PwmOut, write)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (PwmOut, write, (args_count == 1));
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (PwmOut, write, 0, number);
|
||||
|
||||
// Extract native PwmOut pointer
|
||||
void* void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native PwmOut pointer");
|
||||
}
|
||||
|
||||
PwmOut* native_ptr = static_cast<PwmOut*> (void_ptr);
|
||||
|
||||
double arg0 = jerry_value_as_number (args[0]);
|
||||
native_ptr->write (static_cast<float> (arg0));
|
||||
|
||||
return jerry_undefined ();
|
||||
}
|
||||
|
||||
/**
|
||||
* PwmOut#read (native JavaScript method)
|
||||
*
|
||||
* Return the current output duty-cycle setting, measured as a percentage (float)
|
||||
*
|
||||
* @returns
|
||||
* A floating-point value representing the current duty-cycle being output on the pin,
|
||||
* measured as a percentage. The returned value will lie between
|
||||
* 0.0 (representing on 0%) and 1.0 (representing on 100%).
|
||||
*
|
||||
* @note
|
||||
* This value may not match exactly the value set by a previous <write>.
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (PwmOut, read)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (PwmOut, read, (args_count == 0));
|
||||
|
||||
// Extract native PwmOut pointer
|
||||
void* void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native PwmOut pointer");
|
||||
}
|
||||
|
||||
PwmOut* native_ptr = static_cast<PwmOut*> (void_ptr);
|
||||
|
||||
float result = native_ptr->read ();
|
||||
return jerry_number (result);
|
||||
}
|
||||
|
||||
/**
|
||||
* PwmOut#period (native JavaScript method)
|
||||
*
|
||||
* Set the PWM period, specified in seconds (float), keeping the duty cycle the same.
|
||||
*
|
||||
* @note
|
||||
* The resolution is currently in microseconds; periods smaller than this
|
||||
* will be set to zero.
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (PwmOut, period)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (PwmOut, period, (args_count == 1));
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (PwmOut, period, 0, number);
|
||||
|
||||
// Extract native PwmOut pointer
|
||||
void* void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native PwmOut pointer");
|
||||
}
|
||||
|
||||
PwmOut* native_ptr = static_cast<PwmOut*> (void_ptr);
|
||||
|
||||
double arg0 = jerry_value_as_number (args[0]);
|
||||
native_ptr->period (static_cast<float> (arg0));
|
||||
|
||||
return jerry_undefined ();
|
||||
}
|
||||
|
||||
/**
|
||||
* PwmOut#period_ms (native JavaScript method)
|
||||
*
|
||||
* Set the PWM period, specified in milli-seconds (int), keeping the duty cycle the same.
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (PwmOut, period_ms)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (PwmOut, period_ms, (args_count == 1));
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (PwmOut, period_ms, 0, number);
|
||||
|
||||
// Extract native PwmOut pointer
|
||||
void* void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native PwmOut pointer");
|
||||
}
|
||||
|
||||
PwmOut* native_ptr = static_cast<PwmOut*> (void_ptr);
|
||||
|
||||
double arg0 = jerry_value_as_number (args[0]);
|
||||
native_ptr->period_ms (static_cast<int> (arg0));
|
||||
|
||||
return jerry_undefined ();
|
||||
}
|
||||
|
||||
/**
|
||||
* PwmOut#period_us (native JavaScript method)
|
||||
*
|
||||
* Set the PWM period, specified in micro-seconds (int), keeping the duty cycle the same.
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (PwmOut, period_us)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (PwmOut, period_us, (args_count == 1));
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (PwmOut, period_us, 0, number);
|
||||
|
||||
// Extract native PwmOut pointer
|
||||
void* void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native PwmOut pointer");
|
||||
}
|
||||
|
||||
PwmOut* native_ptr = static_cast<PwmOut*> (void_ptr);
|
||||
|
||||
double arg0 = jerry_value_as_number (args[0]);
|
||||
native_ptr->period_us (static_cast<int> (arg0));
|
||||
|
||||
return jerry_undefined ();
|
||||
}
|
||||
|
||||
/**
|
||||
* PwmOut#pulsewidth (native JavaScript method)
|
||||
*
|
||||
* Set the PWM pulsewidth, specified in seconds (float), keeping the period the same.
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (PwmOut, pulsewidth)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (PwmOut, pulsewidth, (args_count == 1));
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (PwmOut, pulsewidth, 0, number);
|
||||
|
||||
// Extract native PwmOut pointer
|
||||
void* void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native PwmOut pointer");
|
||||
}
|
||||
|
||||
PwmOut* native_ptr = static_cast<PwmOut*> (void_ptr);
|
||||
|
||||
double arg0 = jerry_value_as_number (args[0]);
|
||||
native_ptr->pulsewidth (static_cast<float> (arg0));
|
||||
|
||||
return jerry_undefined ();
|
||||
}
|
||||
|
||||
/**
|
||||
* PwmOut#pulsewidth_ms (native JavaScript method)
|
||||
*
|
||||
* Set the PWM pulsewidth, specified in milli-seconds (int), keeping the period the same.
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (PwmOut, pulsewidth_ms)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (PwmOut, pulsewidth_ms, (args_count == 1));
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (PwmOut, pulsewidth_ms, 0, number);
|
||||
|
||||
// Extract native PwmOut pointer
|
||||
void* void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native PwmOut pointer");
|
||||
}
|
||||
|
||||
PwmOut* native_ptr = static_cast<PwmOut*> (void_ptr);
|
||||
|
||||
double arg0 = jerry_value_as_number (args[0]);
|
||||
native_ptr->pulsewidth_ms (static_cast<int> (arg0));
|
||||
|
||||
return jerry_undefined ();
|
||||
}
|
||||
|
||||
/**
|
||||
* PwmOut#pulsewidth_us (native JavaScript method)
|
||||
*
|
||||
* Set the PWM pulsewidth, specified in micro-seconds (int), keeping the period the same.
|
||||
*/
|
||||
DECLARE_CLASS_FUNCTION (PwmOut, pulsewidth_us)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (PwmOut, pulsewidth_us, (args_count == 1));
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (PwmOut, pulsewidth_us, 0, number);
|
||||
|
||||
// Extract native PwmOut pointer
|
||||
void* void_ptr = jerry_object_get_native_ptr (call_info_p->this_value, &native_obj_type_info);
|
||||
|
||||
if (void_ptr == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to get native PwmOut pointer");
|
||||
}
|
||||
|
||||
PwmOut* native_ptr = static_cast<PwmOut*> (void_ptr);
|
||||
|
||||
double arg0 = jerry_value_as_number (args[0]);
|
||||
native_ptr->pulsewidth_us (static_cast<int> (arg0));
|
||||
|
||||
return jerry_undefined ();
|
||||
}
|
||||
|
||||
/**
|
||||
* PwmOut (native JavaScript constructor)
|
||||
*
|
||||
* @param pin_name mbed pin to connect the PwmOut to.
|
||||
* @returns a JavaScript object representing a PwmOut.
|
||||
*/
|
||||
DECLARE_CLASS_CONSTRUCTOR (PwmOut)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (PwmOut, __constructor, args_count == 1);
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (PwmOut, __constructor, 0, number);
|
||||
|
||||
PinName pin_name = PinName (jerry_value_as_number (args[0]));
|
||||
|
||||
// Create the native object
|
||||
PwmOut* native_ptr = new PwmOut (pin_name);
|
||||
|
||||
// create the jerryscript object
|
||||
jerry_value_t js_object = jerry_object ();
|
||||
jerry_object_set_native_ptr (js_object, &native_obj_type_info, native_ptr);
|
||||
|
||||
// attach methods
|
||||
ATTACH_CLASS_FUNCTION (js_object, PwmOut, write);
|
||||
ATTACH_CLASS_FUNCTION (js_object, PwmOut, read);
|
||||
ATTACH_CLASS_FUNCTION (js_object, PwmOut, period);
|
||||
ATTACH_CLASS_FUNCTION (js_object, PwmOut, period_ms);
|
||||
ATTACH_CLASS_FUNCTION (js_object, PwmOut, period_us);
|
||||
ATTACH_CLASS_FUNCTION (js_object, PwmOut, pulsewidth);
|
||||
ATTACH_CLASS_FUNCTION (js_object, PwmOut, pulsewidth_ms);
|
||||
ATTACH_CLASS_FUNCTION (js_object, PwmOut, pulsewidth_us);
|
||||
|
||||
return js_object;
|
||||
}
|
||||
+82
@@ -0,0 +1,82 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#include "jerryscript-mbed-drivers/setInterval-js.h"
|
||||
|
||||
#include "jerryscript-mbed-event-loop/EventLoop.h"
|
||||
|
||||
/**
|
||||
* setInterval (native JavaScript function)
|
||||
*
|
||||
* Call a JavaScript function at fixed intervals.
|
||||
*
|
||||
* @param function Function to call
|
||||
* @param interval Time between function calls, in ms.
|
||||
*/
|
||||
DECLARE_GLOBAL_FUNCTION (setInterval)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (global, setInterval, (args_count == 2));
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (global, setInterval, 0, function);
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (global, setInterval, 1, number);
|
||||
|
||||
int interval = int (jerry_value_as_number (args[1]));
|
||||
|
||||
int id = mbed::js::EventLoop::getInstance ().getQueue ().call_every (interval,
|
||||
jerry_call,
|
||||
args[0],
|
||||
jerry_null (),
|
||||
(jerry_value_t*) NULL,
|
||||
0);
|
||||
|
||||
jerry_value_t result = jerry_object_set_index (call_info_p->function, id, args[0]);
|
||||
|
||||
if (jerry_value_is_exception (result))
|
||||
{
|
||||
jerry_value_free (result);
|
||||
mbed::js::EventLoop::getInstance ().getQueue ().cancel (id);
|
||||
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to run setInterval");
|
||||
}
|
||||
|
||||
jerry_value_free (result);
|
||||
return jerry_number (id);
|
||||
}
|
||||
|
||||
/**
|
||||
* clearInterval (native JavaScript function)
|
||||
*
|
||||
* Cancel an event that was previously scheduled via setInterval.
|
||||
*
|
||||
* @param id ID of the timeout event, returned by setInterval.
|
||||
*/
|
||||
DECLARE_GLOBAL_FUNCTION (clearInterval)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (global, clearInterval, (args_count == 1));
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (global, clearInterval, 0, number);
|
||||
|
||||
int id = int (jerry_value_as_number (args[0]));
|
||||
|
||||
mbed::js::EventLoop::getInstance ().getQueue ().cancel (id);
|
||||
|
||||
jerry_value_t global_obj = jerry_current_realm ();
|
||||
jerry_value_t prop_name = jerry_string_sz ("setInterval");
|
||||
jerry_value_t func_obj = jerry_object_get (global_obj, prop_name);
|
||||
jerry_value_free (prop_name);
|
||||
|
||||
jerry_object_delete_index (func_obj, id);
|
||||
jerry_value_free (func_obj);
|
||||
jerry_value_free (global_obj);
|
||||
|
||||
return jerry_undefined ();
|
||||
}
|
||||
@@ -0,0 +1,82 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#include "jerryscript-mbed-drivers/setTimeout-js.h"
|
||||
|
||||
#include "jerryscript-mbed-event-loop/EventLoop.h"
|
||||
|
||||
/**
|
||||
* setTimeout (native JavaScript function)
|
||||
*
|
||||
* Call a JavaScript function once, after a fixed time period.
|
||||
*
|
||||
* @param function Function to call
|
||||
* @param wait_time Time before function is called, in ms.
|
||||
*/
|
||||
DECLARE_GLOBAL_FUNCTION (setTimeout)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (global, setTimeout, (args_count == 2));
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (global, setTimeout, 0, function);
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (global, setTimeout, 1, number);
|
||||
|
||||
int interval = int (jerry_value_as_number (args[1]));
|
||||
|
||||
int id = mbed::js::EventLoop::getInstance ().getQueue ().call_in (interval,
|
||||
jerry_call,
|
||||
args[0],
|
||||
jerry_null (),
|
||||
(jerry_value_t*) NULL,
|
||||
0);
|
||||
|
||||
jerry_value_t result = jerry_object_set_index (call_info_p->function, id, args[0]);
|
||||
|
||||
if (jerry_value_is_exception (result))
|
||||
{
|
||||
jerry_value_free (result);
|
||||
mbed::js::EventLoop::getInstance ().getQueue ().cancel (id);
|
||||
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, "Failed to run setTimeout");
|
||||
}
|
||||
|
||||
jerry_value_free (result);
|
||||
return jerry_number (id);
|
||||
}
|
||||
|
||||
/**
|
||||
* clearTimeout (native JavaScript function)
|
||||
*
|
||||
* Cancel an event that was previously scheduled via setTimeout.
|
||||
*
|
||||
* @param id ID of the timeout event, returned by setTimeout.
|
||||
*/
|
||||
DECLARE_GLOBAL_FUNCTION (clearTimeout)
|
||||
{
|
||||
CHECK_ARGUMENT_COUNT (global, clearTimeout, (args_count == 1));
|
||||
CHECK_ARGUMENT_TYPE_ALWAYS (global, clearTimeout, 0, number);
|
||||
|
||||
int id = int (jerry_value_as_number (args[0]));
|
||||
|
||||
mbed::js::EventLoop::getInstance ().getQueue ().cancel (id);
|
||||
|
||||
jerry_value_t global_obj = jerry_current_realm ();
|
||||
jerry_value_t prop_name = jerry_string_sz ("setTimeout");
|
||||
jerry_value_t func_obj = jerry_object_get (global_obj, prop_name);
|
||||
jerry_value_free (prop_name);
|
||||
|
||||
jerry_object_delete_index (func_obj, id);
|
||||
jerry_value_free (func_obj);
|
||||
jerry_value_free (global_obj);
|
||||
|
||||
return jerry_undefined ();
|
||||
}
|
||||
@@ -0,0 +1,114 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#ifndef _JERRYSCRIPT_MBED_EVENT_LOOP_BOUND_CALLBACK_H
|
||||
#define _JERRYSCRIPT_MBED_EVENT_LOOP_BOUND_CALLBACK_H
|
||||
|
||||
#include "Callback.h"
|
||||
|
||||
namespace mbed {
|
||||
namespace js {
|
||||
|
||||
template<typename T>
|
||||
class BoundCallback;
|
||||
|
||||
template<typename R, typename A0>
|
||||
class BoundCallback<R(A0)> {
|
||||
public:
|
||||
BoundCallback(Callback<R(A0)> cb, A0 a0) : a0(a0), cb(cb) { }
|
||||
|
||||
void call() {
|
||||
cb(a0);
|
||||
}
|
||||
|
||||
operator Callback<void()>() {
|
||||
Callback<void()> cb(this, &BoundCallback::call);
|
||||
return cb;
|
||||
}
|
||||
|
||||
private:
|
||||
A0 a0;
|
||||
Callback<R(A0)> cb;
|
||||
};
|
||||
|
||||
template<typename R, typename A0, typename A1>
|
||||
class BoundCallback<R(A0, A1)> {
|
||||
public:
|
||||
BoundCallback(Callback<R(A0, A1)> cb, A0 a0, A1 a1) : a0(a0), a1(a1), cb(cb) { }
|
||||
|
||||
void call() {
|
||||
cb(a0, a1);
|
||||
}
|
||||
|
||||
operator Callback<void()>() {
|
||||
Callback<void()> cb(this, &BoundCallback::call);
|
||||
return cb;
|
||||
}
|
||||
|
||||
private:
|
||||
A0 a0;
|
||||
A0 a1;
|
||||
|
||||
Callback<R(A0, A1)> cb;
|
||||
};
|
||||
|
||||
template<typename R, typename A0, typename A1, typename A2>
|
||||
class BoundCallback<R(A0, A1, A2)> {
|
||||
public:
|
||||
BoundCallback(Callback<R(A0, A1, A2)> cb, A0 a0, A1 a1, A2 a2) : a0(a0), a1(a1), a2(a2), cb(cb) { }
|
||||
|
||||
void call() {
|
||||
cb(a0, a1, a2);
|
||||
}
|
||||
|
||||
operator Callback<void()>() {
|
||||
Callback<void()> cb(this, &BoundCallback::call);
|
||||
return cb;
|
||||
}
|
||||
|
||||
private:
|
||||
A0 a0;
|
||||
A1 a1;
|
||||
A2 a2;
|
||||
|
||||
Callback<R(A0, A1, A2)> cb;
|
||||
};
|
||||
|
||||
template<typename R, typename A0, typename A1, typename A2, typename A3>
|
||||
class BoundCallback<R(A0, A1, A2, A3)> {
|
||||
public:
|
||||
BoundCallback(Callback<R(A0, A1, A2, A3)> cb, A0 a0, A1 a1, A2 a2, A3 a3) : a0(a0), a1(a1), a2(a2), a3(a3), cb(cb) { }
|
||||
|
||||
void call() {
|
||||
cb(a0, a1, a2, a3);
|
||||
}
|
||||
|
||||
operator Callback<void()>() {
|
||||
Callback<void()> cb(this, &BoundCallback::call);
|
||||
return cb;
|
||||
}
|
||||
|
||||
private:
|
||||
A0 a0;
|
||||
A1 a1;
|
||||
A2 a2;
|
||||
A3 a3;
|
||||
|
||||
Callback<R(A0, A1, A2, A3)> cb;
|
||||
};
|
||||
|
||||
} // namespace js
|
||||
} // namespace mbed
|
||||
|
||||
#endif // _JERRYSCRIPT_MBED_EVENT_LOOP_BOUND_CALLBACK_H
|
||||
@@ -0,0 +1,99 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#ifndef _JERRYSCRIPT_MBED_EVENT_LOOP_EVENT_LOOP_H
|
||||
#define _JERRYSCRIPT_MBED_EVENT_LOOP_EVENT_LOOP_H
|
||||
|
||||
#include <vector>
|
||||
|
||||
#include "jerry-core/include/jerryscript.h"
|
||||
|
||||
#include "Callback.h"
|
||||
#include "mbed_assert.h"
|
||||
|
||||
#include "events/EventQueue.h"
|
||||
|
||||
#include "jerryscript-mbed-util/logging.h"
|
||||
#include "jerryscript-mbed-event-loop/BoundCallback.h"
|
||||
|
||||
extern "C" void exit(int return_code);
|
||||
|
||||
namespace mbed {
|
||||
namespace js {
|
||||
|
||||
static const uint32_t EVENT_INTERVAL_MS = 1;
|
||||
|
||||
class EventLoop {
|
||||
private:
|
||||
static EventLoop instance;
|
||||
|
||||
public:
|
||||
static EventLoop& getInstance() {
|
||||
return instance;
|
||||
}
|
||||
|
||||
void go() {
|
||||
while (true) {
|
||||
queue.dispatch();
|
||||
}
|
||||
}
|
||||
|
||||
Callback<void()> wrapFunction(jerry_value_t f) {
|
||||
MBED_ASSERT(jerry_value_is_function(f));
|
||||
|
||||
// we need to return a callback that'll schedule this
|
||||
Callback<void(uint32_t)> cb_raw(this, &EventLoop::callback);
|
||||
BoundCallback<void(uint32_t)> *cb = new BoundCallback<void(uint32_t)>(cb_raw, f);
|
||||
|
||||
bound_callbacks.push_back(std::make_pair(f, cb));
|
||||
|
||||
return *cb;
|
||||
}
|
||||
|
||||
void dropCallback(jerry_value_t f) {
|
||||
for (std::vector<std::pair<jerry_value_t, BoundCallback<void(uint32_t)>*> >::iterator it = bound_callbacks.begin(); it != bound_callbacks.end(); it++) {
|
||||
std::pair<jerry_value_t, BoundCallback<void(uint32_t)>*> element = *it;
|
||||
|
||||
if (element.first == f) {
|
||||
delete element.second;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void callback(jerry_value_t f) {
|
||||
queue.call(jerry_call, f, jerry_null(), (const jerry_value_t*)NULL, 0);
|
||||
}
|
||||
|
||||
void nativeCallback(Callback<void()> cb) {
|
||||
queue.call(cb);
|
||||
}
|
||||
|
||||
events::EventQueue& getQueue() {
|
||||
return queue;
|
||||
}
|
||||
|
||||
private:
|
||||
EventLoop() {}
|
||||
|
||||
std::vector<std::pair<jerry_value_t, BoundCallback<void(uint32_t)>*> > bound_callbacks;
|
||||
events::EventQueue queue;
|
||||
};
|
||||
|
||||
void event_loop();
|
||||
|
||||
} // namespace js
|
||||
} // namespace mbed
|
||||
|
||||
#endif // _JERRYSCRIPT_MBED_EVENT_LOOP_EVENT_LOOP_H
|
||||
@@ -0,0 +1,27 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#include "jerryscript-mbed-event-loop/EventLoop.h"
|
||||
|
||||
namespace mbed {
|
||||
namespace js {
|
||||
|
||||
EventLoop EventLoop::instance;
|
||||
|
||||
void event_loop() {
|
||||
EventLoop::getInstance().go();
|
||||
}
|
||||
|
||||
} // namespace js
|
||||
} // namespace mbed
|
||||
@@ -0,0 +1,21 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#ifndef _JERRYSCRIPT_MBED_LAUNCHER_LAUNCHER_H
|
||||
#define _JERRYSCRIPT_MBED_LAUNCHER_LAUNCHER_H
|
||||
|
||||
void jsmbed_js_launch(void);
|
||||
void jsmbed_js_exit(void);
|
||||
|
||||
#endif // _JERRYSCRIPT_MBED_LAUNCHER_LAUNCHER_H
|
||||
@@ -0,0 +1,22 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#ifndef _JERRYSCRIPT_MBED_LAUNCHER_SETUP_H
|
||||
#define _JERRYSCRIPT_MBED_LAUNCHER_SETUP_H
|
||||
|
||||
#include "jerry-core/include/jerryscript.h"
|
||||
|
||||
void jsmbed_js_load_magic_strings(void);
|
||||
|
||||
#endif // _JERRYSCRIPT_MBED_LAUNCHER_SETUP_H
|
||||
@@ -0,0 +1,95 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#include "mbed.h"
|
||||
#include "rtos.h"
|
||||
|
||||
#include "jerry-core/include/jerryscript.h"
|
||||
#include "jerry-core/include/jerryscript-port.h"
|
||||
|
||||
#include "jerryscript-mbed-event-loop/EventLoop.h"
|
||||
|
||||
#include "jerryscript-mbed-util/js_source.h"
|
||||
#include "jerryscript-mbed-library-registry/registry.h"
|
||||
|
||||
#include "jerryscript-mbed-launcher/launcher.h"
|
||||
#include "jerryscript-mbed-launcher/setup.h"
|
||||
|
||||
#include "jerry-targetjs.h"
|
||||
|
||||
DECLARE_JS_CODES;
|
||||
|
||||
/**
|
||||
* load_javascript
|
||||
*
|
||||
* Parse and run javascript files specified in jerry-targetjs.h
|
||||
*/
|
||||
static int load_javascript() {
|
||||
for (int src = 0; js_codes[src].source; src++) {
|
||||
LOG_PRINT("running js file %s\r\n", js_codes[src].name);
|
||||
|
||||
const jerry_char_t* code = reinterpret_cast<const jerry_char_t*>(js_codes[src].source);
|
||||
const size_t length = js_codes[src].length;
|
||||
|
||||
jerry_value_t parsed_code = jerry_parse(code, length, NULL);
|
||||
|
||||
if (jerry_value_is_exception(parsed_code)) {
|
||||
LOG_PRINT_ALWAYS("jerry_parse failed [%s]\r\n", js_codes[src].name);
|
||||
jerry_value_free(parsed_code);
|
||||
jsmbed_js_exit();
|
||||
return -1;
|
||||
}
|
||||
|
||||
jerry_value_t returned_value = jerry_run(parsed_code);
|
||||
jerry_value_free(parsed_code);
|
||||
|
||||
if (jerry_value_is_exception(returned_value)) {
|
||||
LOG_PRINT_ALWAYS("jerry_run failed [%s]\r\n", js_codes[src].name);
|
||||
jerry_value_free(returned_value);
|
||||
jsmbed_js_exit();
|
||||
return -1;
|
||||
}
|
||||
|
||||
jerry_value_free(returned_value);
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int jsmbed_js_init() {
|
||||
union { double d; unsigned u; } now = { .d = jerry_port_get_current_time () };
|
||||
srand (now.u);
|
||||
jerry_init_flag_t flags = JERRY_INIT_EMPTY;
|
||||
jerry_init(flags);
|
||||
|
||||
jsmbed_js_load_magic_strings();
|
||||
mbed::js::LibraryRegistry::getInstance().register_all();
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
void jsmbed_js_exit() {
|
||||
jerry_cleanup();
|
||||
}
|
||||
|
||||
void jsmbed_js_launch() {
|
||||
jsmbed_js_init();
|
||||
|
||||
puts(" JerryScript in mbed\r\n");
|
||||
puts(" build date: " __DATE__ " \r\n");
|
||||
|
||||
if (load_javascript() == 0) {
|
||||
mbed::js::event_loop();
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,54 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#include "jerryscript-mbed-launcher/setup.h"
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
#include "jerryscript-mbed-util/logging.h"
|
||||
|
||||
extern uint32_t jsmbed_js_magic_string_count;
|
||||
extern uint32_t jsmbed_js_magic_string_values[];
|
||||
|
||||
extern const char *jsmbed_js_magic_strings[];
|
||||
extern const jerry_length_t jsmbed_js_magic_string_lengths[];
|
||||
|
||||
void
|
||||
jsmbed_js_load_magic_strings ()
|
||||
{
|
||||
if (jsmbed_js_magic_string_count == 0)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
jerry_register_magic_strings ((const jerry_char_t **) jsmbed_js_magic_strings,
|
||||
jsmbed_js_magic_string_count,
|
||||
jsmbed_js_magic_string_lengths);
|
||||
|
||||
jerry_value_t global = jerry_current_realm ();
|
||||
|
||||
for (unsigned int idx = 0; idx < jsmbed_js_magic_string_count; idx++)
|
||||
{
|
||||
jerry_value_t constant_value = jerry_number (jsmbed_js_magic_string_values[idx]);
|
||||
jerry_value_t magic_string = jerry_string_sz (jsmbed_js_magic_strings[idx]);
|
||||
|
||||
jerry_value_free (jerry_object_set (global, magic_string, constant_value));
|
||||
|
||||
jerry_value_free (constant_value);
|
||||
jerry_value_free (magic_string);
|
||||
}
|
||||
|
||||
jerry_value_free (global);
|
||||
}
|
||||
@@ -0,0 +1,57 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#ifndef _JERRYSCRIPT_MBED_LIBRARY_REGISTRY_REGISTRY_H
|
||||
#define _JERRYSCRIPT_MBED_LIBRARY_REGISTRY_REGISTRY_H
|
||||
|
||||
#include <vector>
|
||||
#include "stdint.h"
|
||||
|
||||
#define JERRY_USE_MBED_LIBRARY(NAME) \
|
||||
mbed::js::LibraryRegistry::getInstance().add(jsmbed_wrap_registry_entry__ ## NAME)
|
||||
|
||||
namespace mbed {
|
||||
namespace js {
|
||||
|
||||
typedef void (*library_registration_function_t)(void);
|
||||
|
||||
class LibraryRegistry {
|
||||
private:
|
||||
static LibraryRegistry instance;
|
||||
|
||||
public:
|
||||
static LibraryRegistry& getInstance() {
|
||||
return instance;
|
||||
}
|
||||
|
||||
void add(library_registration_function_t lib_func) {
|
||||
funcs.push_back(lib_func);
|
||||
}
|
||||
|
||||
void register_all() {
|
||||
for (std::size_t i = 0; i < funcs.size(); i++) {
|
||||
funcs[i]();
|
||||
}
|
||||
}
|
||||
|
||||
private:
|
||||
LibraryRegistry() {}
|
||||
|
||||
std::vector<library_registration_function_t> funcs;
|
||||
};
|
||||
|
||||
} // namespace js
|
||||
} // namespace mbed
|
||||
|
||||
#endif // _JERRYSCRIPT_MBED_LIBRARY_REGISTRY_REGISTRY_H
|
||||
+17
@@ -0,0 +1,17 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#include "jerryscript-mbed-library-registry/registry.h"
|
||||
|
||||
mbed::js::LibraryRegistry mbed::js::LibraryRegistry::instance;
|
||||
+84
@@ -0,0 +1,84 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#include "jerryscript-mbed-library-registry/wrap_tools.h"
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
bool
|
||||
jsmbed_wrap_register_global_function (const char* name, jerry_external_handler_t handler)
|
||||
{
|
||||
jerry_value_t global_object_val = jerry_current_realm ();
|
||||
jerry_value_t reg_function = jerry_function_external (handler);
|
||||
|
||||
bool is_ok = true;
|
||||
|
||||
if (!(jerry_value_is_function (reg_function) && jerry_value_is_constructor (reg_function)))
|
||||
{
|
||||
is_ok = false;
|
||||
LOG_PRINT_ALWAYS ("Error: jerry_function_external failed!\r\n");
|
||||
jerry_value_free (global_object_val);
|
||||
jerry_value_free (reg_function);
|
||||
return is_ok;
|
||||
}
|
||||
|
||||
if (jerry_value_is_exception (reg_function))
|
||||
{
|
||||
is_ok = false;
|
||||
LOG_PRINT_ALWAYS ("Error: jerry_function_external has error flag! \r\n");
|
||||
jerry_value_free (global_object_val);
|
||||
jerry_value_free (reg_function);
|
||||
return is_ok;
|
||||
}
|
||||
|
||||
jerry_value_t jerry_name = jerry_string_sz (name);
|
||||
|
||||
jerry_value_t set_result = jerry_object_set (global_object_val, jerry_name, reg_function);
|
||||
|
||||
if (jerry_value_is_exception (set_result))
|
||||
{
|
||||
is_ok = false;
|
||||
LOG_PRINT_ALWAYS ("Error: jerry_function_external failed: [%s]\r\n", name);
|
||||
}
|
||||
|
||||
jerry_value_free (jerry_name);
|
||||
jerry_value_free (global_object_val);
|
||||
jerry_value_free (reg_function);
|
||||
jerry_value_free (set_result);
|
||||
|
||||
return is_ok;
|
||||
}
|
||||
|
||||
bool
|
||||
jsmbed_wrap_register_class_constructor (const char* name, jerry_external_handler_t handler)
|
||||
{
|
||||
// Register class constructor as a global function
|
||||
return jsmbed_wrap_register_global_function (name, handler);
|
||||
}
|
||||
|
||||
bool
|
||||
jsmbed_wrap_register_class_function (jerry_value_t this_obj, const char* name, jerry_external_handler_t handler)
|
||||
{
|
||||
jerry_value_t property_name = jerry_string_sz (name);
|
||||
jerry_value_t handler_obj = jerry_function_external (handler);
|
||||
|
||||
jerry_value_free (jerry_object_set (this_obj, property_name, handler_obj));
|
||||
|
||||
jerry_value_free (handler_obj);
|
||||
jerry_value_free (property_name);
|
||||
|
||||
// TODO: check for errors, and return false in the case of errors
|
||||
return true;
|
||||
}
|
||||
@@ -0,0 +1,43 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#ifndef _JERRYSCRIPT_MBED_LIBRARY_REGISTRY_WRAP_TOOLS_H
|
||||
#define _JERRYSCRIPT_MBED_LIBRARY_REGISTRY_WRAP_TOOLS_H
|
||||
|
||||
#include <stdlib.h>
|
||||
|
||||
#include "jerry-core/include/jerryscript.h"
|
||||
|
||||
#include "jerryscript-mbed-util/logging.h"
|
||||
#include "jerryscript-mbed-util/wrappers.h"
|
||||
|
||||
|
||||
//
|
||||
// Functions used by the wrapper registration API.
|
||||
//
|
||||
|
||||
bool
|
||||
jsmbed_wrap_register_global_function (const char* name,
|
||||
jerry_external_handler_t handler);
|
||||
|
||||
bool
|
||||
jsmbed_wrap_register_class_constructor (const char* name,
|
||||
jerry_external_handler_t handler);
|
||||
|
||||
bool
|
||||
jsmbed_wrap_register_class_function (jerry_value_t this_obj_p,
|
||||
const char* name,
|
||||
jerry_external_handler_t handler);
|
||||
|
||||
#endif // _JERRYSCRIPT_MBED_LIBRARY_REGISTRY_WRAP_TOOLS_H
|
||||
@@ -0,0 +1,24 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#ifndef _JERRYSCRIPT_MBED_UTIL_JS_SOURCE_H
|
||||
#define _JERRYSCRIPT_MBED_UTIL_JS_SOURCE_H
|
||||
|
||||
struct jsmbed_js_source_t {
|
||||
const char* name;
|
||||
const char* source;
|
||||
const int length;
|
||||
};
|
||||
|
||||
#endif // _JERRYSCRIPT_MBED_UTIL_JS_SOURCE_H
|
||||
@@ -0,0 +1,28 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#ifndef _JERRYSCRIPT_MBED_UTIL_LOGGING_H
|
||||
#define _JERRYSCRIPT_MBED_UTIL_LOGGING_H
|
||||
|
||||
#include "mbed.h"
|
||||
|
||||
#ifdef DEBUG_WRAPPER
|
||||
#define LOG_PRINT(...) printf(__VA_ARGS__)
|
||||
#else /* !defined(DEBUG_WRAPPER) */
|
||||
#define LOG_PRINT(...) while(0) { }
|
||||
#endif /* defined(DEBUG_WRAPPER) */
|
||||
|
||||
#define LOG_PRINT_ALWAYS(...) printf(__VA_ARGS__)
|
||||
|
||||
#endif // _JERRYSCRIPT_MBED_UTIL_LOGGING_H
|
||||
@@ -0,0 +1,91 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#ifndef _JERRYSCRIPT_MBED_UTIL_WRAPPERS_H
|
||||
#define _JERRYSCRIPT_MBED_UTIL_WRAPPERS_H
|
||||
|
||||
/*
|
||||
* Used in header/source files for wrappers, to declare the signature of the
|
||||
* registration function.
|
||||
*/
|
||||
#define DECLARE_JS_WRAPPER_REGISTRATION(NAME) void jsmbed_wrap_registry_entry__##NAME (void)
|
||||
|
||||
//
|
||||
// 2. Wrapper function declaration/use macros
|
||||
//
|
||||
|
||||
// Global functions
|
||||
#define DECLARE_GLOBAL_FUNCTION(NAME) \
|
||||
jerry_value_t NAME_FOR_GLOBAL_FUNCTION ( \
|
||||
NAME) (const jerry_call_info_t* call_info_p, const jerry_value_t args[], const jerry_length_t args_count)
|
||||
|
||||
#define REGISTER_GLOBAL_FUNCTION(NAME) jsmbed_wrap_register_global_function (#NAME, NAME_FOR_GLOBAL_FUNCTION (NAME))
|
||||
|
||||
#define REGISTER_GLOBAL_FUNCTION_WITH_HANDLER(NAME, HANDLER) jsmbed_wrap_register_global_function (#NAME, HANDLER)
|
||||
|
||||
// Class constructors
|
||||
#define DECLARE_CLASS_CONSTRUCTOR(CLASS) \
|
||||
jerry_value_t NAME_FOR_CLASS_CONSTRUCTOR ( \
|
||||
CLASS) (const jerry_call_info_t* call_info_p, const jerry_value_t args[], const jerry_length_t args_count)
|
||||
|
||||
#define REGISTER_CLASS_CONSTRUCTOR(CLASS) \
|
||||
jsmbed_wrap_register_class_constructor (#CLASS, NAME_FOR_CLASS_CONSTRUCTOR (CLASS))
|
||||
|
||||
// Class functions
|
||||
#define DECLARE_CLASS_FUNCTION(CLASS, NAME) \
|
||||
jerry_value_t NAME_FOR_CLASS_FUNCTION (CLASS, NAME) (const jerry_call_info_t* call_info_p, \
|
||||
const jerry_value_t args[], \
|
||||
const jerry_length_t args_count)
|
||||
|
||||
#define ATTACH_CLASS_FUNCTION(OBJECT, CLASS, NAME) \
|
||||
jsmbed_wrap_register_class_function (OBJECT, #NAME, NAME_FOR_CLASS_FUNCTION (CLASS, NAME))
|
||||
|
||||
//
|
||||
// 3. Argument checking macros
|
||||
//
|
||||
#define CHECK_ARGUMENT_COUNT(CLASS, NAME, EXPR) \
|
||||
if (!(EXPR)) \
|
||||
{ \
|
||||
const char* error_msg = "ERROR: wrong argument count for " #CLASS "." #NAME ", expected " #EXPR "."; \
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, error_msg); \
|
||||
}
|
||||
|
||||
#define CHECK_ARGUMENT_TYPE_ALWAYS(CLASS, NAME, INDEX, TYPE) \
|
||||
if (!jerry_value_is_##TYPE (args[INDEX])) \
|
||||
{ \
|
||||
const char* error_msg = \
|
||||
"ERROR: wrong argument type for " #CLASS "." #NAME ", expected argument " #INDEX " to be a " #TYPE ".\n"; \
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, error_msg); \
|
||||
}
|
||||
|
||||
#define CHECK_ARGUMENT_TYPE_ON_CONDITION(CLASS, NAME, INDEX, TYPE, EXPR) \
|
||||
if ((EXPR)) \
|
||||
{ \
|
||||
if (!jerry_value_is_##TYPE (args[INDEX])) \
|
||||
{ \
|
||||
const char* error_msg = \
|
||||
"ERROR: wrong argument type for " #CLASS "." #NAME ", expected argument " #INDEX " to be a " #TYPE ".\n"; \
|
||||
return jerry_throw_sz (JERRY_ERROR_TYPE, error_msg); \
|
||||
} \
|
||||
}
|
||||
|
||||
#define NAME_FOR_GLOBAL_FUNCTION(NAME) __gen_jsmbed_global_func_##NAME
|
||||
#define NAME_FOR_CLASS_CONSTRUCTOR(CLASS) __gen_jsmbed_class_constructor_##CLASS
|
||||
#define NAME_FOR_CLASS_FUNCTION(CLASS, NAME) __gen_jsmbed_func_c_##CLASS##_f_##NAME
|
||||
|
||||
#define NAME_FOR_CLASS_NATIVE_CONSTRUCTOR(CLASS, TYPELIST) __gen_native_jsmbed_##CLASS##__Special_create_##TYPELIST
|
||||
#define NAME_FOR_CLASS_NATIVE_DESTRUCTOR(CLASS) __gen_native_jsmbed_##CLASS##__Special_destroy
|
||||
#define NAME_FOR_CLASS_NATIVE_FUNCTION(CLASS, NAME) __gen_native_jsmbed_##CLASS##_##NAME
|
||||
|
||||
#endif // _JERRYSCRIPT_MBED_UTIL_WRAPPERS_H
|
||||
@@ -0,0 +1,76 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
var led = 0;
|
||||
|
||||
// Setting the pin to 0 turns the LED on
|
||||
var led_off = 1;
|
||||
var led_on = 0;
|
||||
|
||||
var digital_outs = [];
|
||||
|
||||
var leds = [LED1, LED2, LED3, LED4];
|
||||
|
||||
function connect_pins() {
|
||||
print("Creating new DigitalOuts");
|
||||
digital_outs = [];
|
||||
for (var i = 0; i < 4; i++) {
|
||||
digital_outs.push(DigitalOut(leds[i], led_off));
|
||||
if (digital_outs[i].is_connected()) {
|
||||
print("LED " + i + " is connected.");
|
||||
}
|
||||
else {
|
||||
print("LED " + i + " is not connected.");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
connect_pins();
|
||||
|
||||
function blink() {
|
||||
digital_outs[0].write(led_off);
|
||||
digital_outs[1].write(led_off);
|
||||
digital_outs[2].write(led_off);
|
||||
digital_outs[3].write(led_off);
|
||||
|
||||
digital_outs[led].write(led_on);
|
||||
|
||||
print("Finished with LED " + led);
|
||||
led = (led + 1) % 4;
|
||||
}
|
||||
|
||||
// BUTTON2 on NRF52
|
||||
// USER_BUTTON on NUCLEO
|
||||
// SW2 on the K64F
|
||||
// BTN0 on EFM32GG
|
||||
var button;
|
||||
|
||||
/* global BUTTON2, SW2, USER_BUTTON, BTN0 */
|
||||
if (typeof BUTTON2 !== 'undefined') {
|
||||
button = InterruptIn(BUTTON2);
|
||||
} else if (typeof SW2 !== 'undefined') {
|
||||
button = InterruptIn(SW2);
|
||||
} else if (typeof USER_BUTTON !== 'undefined') {
|
||||
button = InterruptIn(USER_BUTTON);
|
||||
} else if (typeof BTN0 !== 'undefined') {
|
||||
button = InterruptIn(BTN0);
|
||||
} else {
|
||||
print("no button specified");
|
||||
}
|
||||
button.fall(function() {
|
||||
print("YOU PUSHED THE BUTTON!");
|
||||
});
|
||||
|
||||
print("flash_leds.js has finished executing.");
|
||||
@@ -0,0 +1,20 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
setInterval(function() {
|
||||
blink();
|
||||
}, 1000);
|
||||
|
||||
print("main.js has finished executing.");
|
||||
@@ -0,0 +1 @@
|
||||
https://github.com/ARMmbed/mbed-os/#e4b81f67f939a0c0b11c147ce74aa367271e1279
|
||||
@@ -0,0 +1,7 @@
|
||||
{
|
||||
"target_overrides": {
|
||||
"NRF52_DK": {
|
||||
"target.uart_hwfc": 0
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,92 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#define _BSD_SOURCE
|
||||
#include <stdarg.h>
|
||||
#include <stdlib.h>
|
||||
#include <sys/time.h>
|
||||
|
||||
#include "jerry-core/include/jerryscript-port.h"
|
||||
|
||||
#include "us_ticker_api.h"
|
||||
|
||||
#ifndef JSMBED_OVERRIDE_JERRY_PORT_LOG
|
||||
/**
|
||||
* Provide log message implementation for the engine.
|
||||
*/
|
||||
void
|
||||
jerry_port_log (jerry_log_level_t level, /**< log level */
|
||||
const char *format, /**< format string */
|
||||
...) /**< parameters */
|
||||
{
|
||||
(void) level; /* ignore log level */
|
||||
|
||||
va_list args;
|
||||
va_start (args, format);
|
||||
vfprintf (stderr, format, args);
|
||||
va_end (args);
|
||||
|
||||
if (strlen (format) == 1 && format[0] == 0x0a) /* line feed (\n) */
|
||||
{
|
||||
printf ("\r"); /* add CR for proper display in serial monitors */
|
||||
}
|
||||
} /* jerry_port_log */
|
||||
#endif /* JSMBED_OVERRIDE_JERRY_PORT_LOG */
|
||||
|
||||
/**
|
||||
* Implementation of jerry_port_get_local_time_zone_adjustment.
|
||||
*
|
||||
* @return 0, as we live in UTC.
|
||||
*/
|
||||
double
|
||||
jerry_port_get_local_time_zone_adjustment (double unix_ms, bool is_utc)
|
||||
{
|
||||
return 0;
|
||||
} /* jerry_port_get_local_time_zone_adjustment */
|
||||
|
||||
/**
|
||||
* Implementation of jerry_port_get_current_time.
|
||||
*
|
||||
* @return current timer's counter value in milliseconds
|
||||
*/
|
||||
double
|
||||
jerry_port_get_current_time (void)
|
||||
{
|
||||
static uint64_t last_tick = 0;
|
||||
static time_t last_time = 0;
|
||||
static uint32_t skew = 0;
|
||||
|
||||
uint64_t curr_tick = us_ticker_read (); /* The value is in microseconds. */
|
||||
time_t curr_time = time(NULL); /* The value is in seconds. */
|
||||
double result = curr_time * 1000;
|
||||
|
||||
/* The us_ticker_read () has an overflow for each UINT_MAX microseconds
|
||||
* (~71 mins). For each overflow event the ticker-based clock is about 33
|
||||
* milliseconds fast. Without a timer thread the milliseconds part of the
|
||||
* time can be corrected if the difference of two get_current_time calls
|
||||
* are within the mentioned 71 mins. Above that interval we can assume
|
||||
* that the milliseconds part of the time is negligibe.
|
||||
*/
|
||||
if (curr_time - last_time > (time_t) (((uint32_t) - 1) / 1000000)) {
|
||||
skew = 0;
|
||||
} else if (last_tick > curr_tick) {
|
||||
skew = (skew + 33) % 1000;
|
||||
}
|
||||
result += (curr_tick / 1000 - skew) % 1000;
|
||||
|
||||
last_tick = curr_tick;
|
||||
last_time = curr_time;
|
||||
return result;
|
||||
} /* jerry_port_get_current_time */
|
||||
@@ -0,0 +1,10 @@
|
||||
cmake/*
|
||||
docs/*
|
||||
jerry-main/*
|
||||
jerry-math/*
|
||||
jerry-port/default/default-date.c
|
||||
jerry-port/default/default-io.c
|
||||
targets/*
|
||||
tests/*
|
||||
third-party/*
|
||||
tools/*
|
||||
Executable
+31
@@ -0,0 +1,31 @@
|
||||
#!/bin/bash
|
||||
|
||||
# Copyright JS Foundation and other contributors, http://js.foundation
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
|
||||
# If we're checking only for global variable definitions of pins, then
|
||||
# file ordering doesn't matter. This is because:
|
||||
#
|
||||
# var a = b;
|
||||
# var b = 7;
|
||||
#
|
||||
# will be accepted by jshint, just 'a' will evaluate to 'undefined'.
|
||||
# Awkward, but at least it means we can have pins.js included at any
|
||||
# point in the clump of files and it won't give us false positives.
|
||||
|
||||
cat js/*.js | jshint -c tools/jshint.conf - | grep "not defined"
|
||||
if [ "$?" == 0 ]; then
|
||||
exit 1
|
||||
fi
|
||||
exit 0
|
||||
@@ -0,0 +1,17 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*
|
||||
* This file is intentionally blank, and is used as a dummy cmsis.h file
|
||||
* when preprocessing generate_pins.py.
|
||||
*/
|
||||
@@ -0,0 +1,221 @@
|
||||
#!/usr/bin/env python
|
||||
|
||||
# Copyright JS Foundation and other contributors, http://js.foundation
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
"""
|
||||
Generate pins.cpp for a specified target, using target definitions from the
|
||||
mbed OS source tree.
|
||||
|
||||
It's expecting to be run from the targets/os/mbedos5 directory.
|
||||
"""
|
||||
|
||||
from __future__ import print_function
|
||||
|
||||
import argparse
|
||||
import ast
|
||||
|
||||
import sys
|
||||
import os
|
||||
|
||||
from pycparserext.ext_c_parser import GnuCParser
|
||||
from pycparser import parse_file, c_ast
|
||||
|
||||
# import mbed tools
|
||||
sys.path.append(os.path.join(os.path.dirname(__file__), '..', 'mbed-os'))
|
||||
from tools.targets import Target
|
||||
|
||||
LICENSE = '''/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the \"License\");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an \"AS IS\" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*
|
||||
* This file is generated by generate_pins.py. Please do not modify.
|
||||
*/
|
||||
'''
|
||||
|
||||
|
||||
def find_file(root_dir, directories, name):
|
||||
"""
|
||||
Find the first instance of file with name 'name' in the directory tree
|
||||
starting with 'root_dir'.
|
||||
|
||||
Filter out directories that are not in directories, or do not start with
|
||||
TARGET_.
|
||||
|
||||
Since this looks in (essentially )the same directories as the compiler would
|
||||
when compiling mbed OS, we should only find one PinNames.h.
|
||||
"""
|
||||
|
||||
for root, dirs, files in os.walk(root_dir, topdown=True):
|
||||
# modify dirs in place
|
||||
dirs[:] = [directory for directory in dirs if directory in directories or not directory.startswith('TARGET_')]
|
||||
|
||||
if name in files:
|
||||
return os.path.join(root, name)
|
||||
|
||||
|
||||
def enumerate_includes(root_dir, directories):
|
||||
"""
|
||||
Walk through the directory tree, starting at root_dir, and enumerate all
|
||||
valid include directories.
|
||||
"""
|
||||
for root, dirs, _ in os.walk(root_dir, topdown=True):
|
||||
# modify dirs in place
|
||||
dirs[:] = [dir_label for dir_label in dirs
|
||||
if dir_label in directories
|
||||
or (not dir_label.startswith('TARGET_')
|
||||
and not dir_label.startswith('TOOLCHAIN_'))]
|
||||
yield root
|
||||
|
||||
|
||||
class TypeDeclVisitor(c_ast.NodeVisitor):
|
||||
"""
|
||||
A TypeDecl visitor class that walks the ast and calls a visitor function for every node found.
|
||||
"""
|
||||
def __init__(self, filter_names=None):
|
||||
self.names = filter_names or []
|
||||
|
||||
def visit(self, node):
|
||||
value = None
|
||||
|
||||
if node.__class__.__name__ == "TypeDecl":
|
||||
value = self.visit_typedecl(node)
|
||||
|
||||
if value is None:
|
||||
for _, child_node in node.children():
|
||||
value = value or self.visit(child_node)
|
||||
|
||||
return value
|
||||
|
||||
def visit_typedecl(self, node):
|
||||
"""
|
||||
Visit a node.
|
||||
"""
|
||||
if node.declname in self.names:
|
||||
return [pin.name for pin in node.type.values.enumerators]
|
||||
|
||||
|
||||
def enumerate_pins(c_source_file, include_dirs, definitions):
|
||||
"""
|
||||
Enumerate pins specified in PinNames.h, by looking for a PinName enum
|
||||
typedef somewhere in the file.
|
||||
"""
|
||||
definitions += ['__attribute(x)__=', '__extension__(x)=', 'register=', '__IO=', 'uint32_t=unsigned int']
|
||||
|
||||
gcc_args = ['-E', '-fmerge-all-constants']
|
||||
gcc_args += ['-I' + directory for directory in include_dirs]
|
||||
|
||||
gcc_args += ['-D' + definition for definition in definitions]
|
||||
parsed_ast = parse_file(c_source_file,
|
||||
use_cpp=True,
|
||||
cpp_path='arm-none-eabi-gcc',
|
||||
cpp_args=gcc_args,
|
||||
parser=GnuCParser())
|
||||
|
||||
# now, walk the AST
|
||||
visitor = TypeDeclVisitor(['PinName'])
|
||||
return visitor.visit(parsed_ast)
|
||||
|
||||
|
||||
def write_pins_to_file(pins, pins_file, out_cpp_file):
|
||||
"""
|
||||
Write the generated pins for a specified mbed board into the output C++ file.
|
||||
"""
|
||||
|
||||
include = '\n#include "../{}"'.format(pins_file)
|
||||
|
||||
count = '''
|
||||
unsigned int jsmbed_js_magic_string_count = {};
|
||||
'''.format(len(pins))
|
||||
|
||||
lengths = ',\n '.join(str(len(pin)) for pin in pins)
|
||||
lenghts_source = '''
|
||||
unsigned int jsmbed_js_magic_string_lengths[] = {
|
||||
%s
|
||||
};
|
||||
''' % lengths
|
||||
|
||||
magic_values = ',\n '.join(pins)
|
||||
magic_source = '''
|
||||
int jsmbed_js_magic_string_values[] = {
|
||||
%s
|
||||
};
|
||||
''' % magic_values
|
||||
|
||||
magic_strings = ',\n '.join('"' + pin + '"' for pin in pins)
|
||||
magic_string_source = '''
|
||||
const char * jsmbed_js_magic_strings[] = {
|
||||
%s
|
||||
};
|
||||
''' % magic_strings
|
||||
|
||||
out_cpp_file.write(LICENSE + include + count + lenghts_source + magic_source + magic_string_source)
|
||||
|
||||
|
||||
def main():
|
||||
"""
|
||||
Perform the main function of this program
|
||||
"""
|
||||
if not os.path.exists('./mbed-os'):
|
||||
print("Fatal: mbed-os directory does not exist.")
|
||||
print("Try running 'make getlibs'")
|
||||
sys.exit(1)
|
||||
|
||||
description = """
|
||||
Generate pins.cpp for a specified mbed board, using target definitions from the
|
||||
mbed OS source tree.
|
||||
"""
|
||||
|
||||
parser = argparse.ArgumentParser(description=description)
|
||||
|
||||
parser.add_argument('board', help='mbed board name')
|
||||
parser.add_argument('-c',
|
||||
help='Output C++ file (default: %(default)s)',
|
||||
default='source/pins.cpp',
|
||||
type=argparse.FileType('w'))
|
||||
|
||||
args = parser.parse_args()
|
||||
board_name = args.board.upper()
|
||||
|
||||
target = Target.get_target(board_name)
|
||||
|
||||
directory_labels = ['TARGET_' + label for label in target.labels] + target.macros
|
||||
|
||||
targets_dir = os.path.join('.', 'mbed-os', 'targets')
|
||||
|
||||
pins_file = find_file(targets_dir, directory_labels, 'PinNames.h')
|
||||
|
||||
includes = enumerate_includes(targets_dir, directory_labels)
|
||||
defines = list(directory_labels)
|
||||
|
||||
# enumerate pins from PinNames.h
|
||||
pins = enumerate_pins(pins_file, ['./tools'] + list(includes), defines)
|
||||
|
||||
# first sort alphabetically, then by length.
|
||||
pins = sorted(pins, key=lambda x: (len(x), x.lower()))
|
||||
|
||||
write_pins_to_file(pins, pins_file, args.c)
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
||||
@@ -0,0 +1,4 @@
|
||||
{
|
||||
"undef": true,
|
||||
"predef": ["print", "BLEDevice", "BLEService", "BLECharacteristic", "DigitalOut", "I2C", "setInterval", "setTimeout", "InterruptIn", "LWIPInterface", "SimpleMbedClient", "M2MBase"]
|
||||
}
|
||||
@@ -0,0 +1,2 @@
|
||||
pycparserext
|
||||
simpleeval
|
||||
@@ -0,0 +1,7 @@
|
||||
# Files generated / copied by the NuttX build
|
||||
.built
|
||||
.depend
|
||||
Make.dep
|
||||
*.c.obj
|
||||
*.o
|
||||
*.a
|
||||
@@ -0,0 +1,20 @@
|
||||
#
|
||||
# For a description of the syntax of this configuration file,
|
||||
# see the file kconfig-language.txt in the NuttX tools repository.
|
||||
#
|
||||
|
||||
config INTERPRETERS_JERRYSCRIPT
|
||||
bool "Jerryscript JavaScript engine"
|
||||
default n
|
||||
|
||||
if INTERPRETERS_JERRYSCRIPT
|
||||
|
||||
config INTERPRETERS_JERRYSCRIPT_PRIORITY
|
||||
int "Jerryscript priority"
|
||||
default 100
|
||||
|
||||
config INTERPRETERS_JERRYSCRIPT_STACKSIZE
|
||||
int "Jerryscript stack size"
|
||||
default 16384
|
||||
|
||||
endif # INTERPRETERS_JERRYSCRIPT
|
||||
@@ -0,0 +1,17 @@
|
||||
# Copyright JS Foundation and other contributors, http://js.foundation
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
|
||||
ifeq ($(CONFIG_INTERPRETERS_JERRYSCRIPT),y)
|
||||
CONFIGURED_APPS += $(APPDIR)/interpreters/jerryscript
|
||||
endif
|
||||
@@ -0,0 +1,71 @@
|
||||
# Copyright JS Foundation and other contributors, http://js.foundation
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
|
||||
include $(APPDIR)/Make.defs
|
||||
|
||||
# Jerryscript built-in application information.
|
||||
PROGNAME = jerry
|
||||
PRIORITY = $(CONFIG_INTERPRETERS_JERRYSCRIPT_PRIORITY)
|
||||
STACKSIZE = $(CONFIG_INTERPRETERS_JERRYSCRIPT_STACKSIZE)
|
||||
|
||||
# Path to the JerryScript and NuttX projects. If not specified, it is
|
||||
# supposed that JerryScript is located next to the nuttx folder.
|
||||
JERRYSCRIPT_ROOT_DIR ?= ../../../../jerryscript
|
||||
NUTTX_ROOT_DIR ?= $(JERRYSCRIPT_ROOT_DIR)/../nuttx
|
||||
|
||||
CFLAGS += -std=c99
|
||||
CFLAGS += -I$(JERRYSCRIPT_ROOT_DIR)/jerry-core/include
|
||||
CFLAGS += -I$(JERRYSCRIPT_ROOT_DIR)/jerry-ext/include
|
||||
CFLAGS += -I$(JERRYSCRIPT_ROOT_DIR)/jerry-math/include
|
||||
|
||||
# These libs should be copied from the JerryScript project.
|
||||
LIBS = libjerry-core.a libjerry-ext.a libjerry-math.a
|
||||
|
||||
ASRCS = setjmp.S
|
||||
CSRCS = jerry_port.c jerry_module.c
|
||||
MAINSRC = jerry_main.c
|
||||
|
||||
.PHONY: copylibs
|
||||
copylibs:
|
||||
cp $(JERRYSCRIPT_ROOT_DIR)/build/lib/lib*.a .
|
||||
|
||||
$(LIBS): copylibs
|
||||
$(firstword $(AR)) x $@
|
||||
|
||||
.PHONY: updateobjs
|
||||
updateobjs:
|
||||
$(eval OBJS += $(shell find . -name "*.obj"))
|
||||
|
||||
.PHONY: cleanlibs
|
||||
cleanlibs: updateobjs
|
||||
rm -f $(OBJS)
|
||||
|
||||
.PHONY: libjerry
|
||||
libjerry:
|
||||
$(JERRYSCRIPT_ROOT_DIR)/tools/build.py \
|
||||
--clean \
|
||||
--lto=OFF \
|
||||
--jerry-cmdline=OFF \
|
||||
--jerry-math=ON \
|
||||
--amalgam=ON \
|
||||
--mem-heap=70 \
|
||||
--profile=es.next \
|
||||
--compile-flag="--sysroot=${NUTTX_ROOT_DIR}" \
|
||||
--toolchain=$(abspath $(JERRYSCRIPT_ROOT_DIR)/cmake/toolchain_mcu_stm32f4.cmake)
|
||||
|
||||
clean:: cleanlibs
|
||||
|
||||
archive: libjerry $(LIBS) updateobjs
|
||||
|
||||
include $(APPDIR)/Application.mk
|
||||
@@ -0,0 +1,65 @@
|
||||
# Copyright JS Foundation and other contributors, http://js.foundation
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
|
||||
|
||||
# Default target for running the build test outside the Travis CI environment.
|
||||
all:
|
||||
$(MAKE) install
|
||||
$(MAKE) script
|
||||
|
||||
|
||||
## Targets for installing build dependencies of the NuttX JerryScript target.
|
||||
|
||||
# Install cross-compiler and tools via apt.
|
||||
install-apt-get-deps:
|
||||
sudo apt-get install -q -y gcc-arm-none-eabi gperf
|
||||
|
||||
# Fetch and build kconfig-frontends (kconfig-conf) from nuttx/tools.
|
||||
LOCAL_INSTALL:=$(CURDIR)/../local/
|
||||
|
||||
install-kconfig:
|
||||
git clone https://bitbucket.org/nuttx/tools.git ../tools
|
||||
mkdir -p $(LOCAL_INSTALL)
|
||||
# FIXME: 'autoreconf --force --install' is a workaround after
|
||||
# https://bitbucket.org/nuttx/tools/commits/164450f982b404fdc2b3233db51dc3eaa1f08b7f
|
||||
cd ../tools/kconfig-frontends && autoreconf --force --install && ./configure --disable-mconf --disable-nconf --disable-gconf --disable-qconf --disable-shared --enable-static --prefix=$(LOCAL_INSTALL)
|
||||
$(MAKE) -C ../tools/kconfig-frontends
|
||||
$(MAKE) -C ../tools/kconfig-frontends install
|
||||
|
||||
# Fetch nuttx/{apps,nuttx} repositories.
|
||||
install-clone-nuttx:
|
||||
git clone https://github.com/apache/incubator-nuttx-apps.git ../apps -b releases/10.2
|
||||
git clone https://github.com/apache/incubator-nuttx.git ../nuttx -b releases/10.2
|
||||
|
||||
# Perform all the necessary (JerryScript-independent) installation steps.
|
||||
install-noapt: install-kconfig install-clone-nuttx
|
||||
install: install-apt-get-deps install-noapt
|
||||
|
||||
|
||||
## Targets for building NuttX with JerryScript.
|
||||
|
||||
# Link in the NuttX JerryScript target directory under the NuttX apps tree.
|
||||
script-add-jerryscript-app:
|
||||
ln -s ../../jerryscript/targets/os/nuttx ../apps/interpreters/jerryscript
|
||||
|
||||
# Configure USB shell.
|
||||
script-configure-usbnsh:
|
||||
cd ../nuttx/tools && PATH=$(LOCAL_INSTALL)/bin:$$PATH ./configure.sh stm32f4discovery:usbnsh
|
||||
|
||||
# Configure and build the firmware (NuttX with JerryScript).
|
||||
script: script-add-jerryscript-app script-configure-usbnsh
|
||||
echo 'CONFIG_ARCH_FPU=y' >> ../nuttx/.config
|
||||
echo 'CONFIG_INTERPRETERS_JERRYSCRIPT=y'>> ../nuttx/.config
|
||||
PATH=$(LOCAL_INSTALL)/bin:$$PATH $(MAKE) -C ../nuttx olddefconfig
|
||||
PATH=$(LOCAL_INSTALL)/bin:$$PATH $(MAKE) -C ../nuttx
|
||||
@@ -0,0 +1,297 @@
|
||||
### About
|
||||
|
||||
This folder contains files to run JerryScript on
|
||||
[STM32F4-Discovery board](https://www.st.com/en/evaluation-tools/stm32f4discovery.html) with
|
||||
[NuttX](https://nuttx.apache.org/).
|
||||
The document had been validated on Ubuntu 20.04 operating system.
|
||||
|
||||
### How to build
|
||||
|
||||
#### 1. Setup the build environment for STM32F4-Discovery board
|
||||
|
||||
Clone the necessary projects into a `jerry-nuttx` directory.
|
||||
The latest tested working version of NuttX is 10.2.
|
||||
|
||||
```sh
|
||||
# Create a base folder for all the projects.
|
||||
mkdir jerry-nuttx && cd jerry-nuttx
|
||||
|
||||
git clone https://github.com/jerryscript-project/jerryscript.git
|
||||
git clone https://github.com/apache/incubator-nuttx.git nuttx -b releases/10.2
|
||||
git clone https://github.com/apache/incubator-nuttx-apps.git apps -b releases/10.2
|
||||
git clone https://bitbucket.org/nuttx/tools.git tools
|
||||
git clone https://github.com/texane/stlink.git -b v1.5.1-patch
|
||||
```
|
||||
|
||||
The following directory structure is created after these commands:
|
||||
|
||||
```
|
||||
jerry-nuttx
|
||||
+ jerryscript
|
||||
| + targets
|
||||
| + os
|
||||
| + nuttx
|
||||
+ nuttx
|
||||
+ apps
|
||||
+ tools
|
||||
+ stlink
|
||||
```
|
||||
|
||||
#### 2. Install dependencies of the projects
|
||||
|
||||
```sh
|
||||
# Assuming you are in jerry-nuttx folder.
|
||||
jerryscript/tools/apt-get-install-deps.sh
|
||||
|
||||
# Toolchain dependencies of NuttX.
|
||||
sudo apt install gcc-arm-none-eabi binutils-arm-none-eabi
|
||||
|
||||
# Tool dependencies of NuttX.
|
||||
sudo apt install \
|
||||
bison flex gettext texinfo libncurses5-dev libncursesw5-dev \
|
||||
gperf automake libtool pkg-config build-essential gperf genromfs \
|
||||
libgmp-dev libmpc-dev libmpfr-dev libisl-dev binutils-dev libelf-dev \
|
||||
libexpat-dev gcc-multilib g++-multilib picocom u-boot-tools util-linux
|
||||
|
||||
# ST-Link and serial communication dependencies.
|
||||
sudo apt install libusb-1.0-0-dev minicom
|
||||
```
|
||||
|
||||
#### 3. Copy JerryScript's application files to NuttX
|
||||
|
||||
Move JerryScript application files to `apps/interpreters/jerryscript` folder.
|
||||
|
||||
```sh
|
||||
# Assuming you are in jerry-nuttx folder.
|
||||
mkdir -p apps/interpreters/jerryscript
|
||||
cp jerryscript/targets/os/nuttx/* apps/interpreters/jerryscript/
|
||||
|
||||
# Or more simply:
|
||||
# ln -s jerryscript/targets/os/nuttx apps/interpreters/jerryscript
|
||||
```
|
||||
|
||||
#### 4. Build kconfig-frontend to configure NuttX
|
||||
|
||||
Skip this section if `kconfig-frontends` had alrady been installed by package manager.
|
||||
|
||||
```sh
|
||||
# Assuming you are in jerry-nuttx folder.
|
||||
cd tools/kconfig-frontends
|
||||
|
||||
./configure \
|
||||
--disable-nconf \
|
||||
--disable-gconf \
|
||||
--disable-qconf \
|
||||
--disable-shared \
|
||||
--enable-static \
|
||||
--prefix=${PWD}/install
|
||||
|
||||
make
|
||||
make install
|
||||
# Add install folder to PATH
|
||||
PATH=${PWD}/install/bin:$PATH
|
||||
```
|
||||
|
||||
#### 5. Configure NuttX
|
||||
|
||||
Configure NuttX for serial communication. A `.config` file contains all the options for the build.
|
||||
|
||||
```sh
|
||||
# Assuming you are in jerry-nuttx folder.
|
||||
cd nuttx/tools
|
||||
|
||||
# Configure NuttX to use USB console shell.
|
||||
./configure.sh stm32f4discovery:usbnsh
|
||||
```
|
||||
|
||||
By default, JerryScript is disabled so it is needed to modify the configuration file. It can
|
||||
be done by using menuconfig (section 5.1) or modifying the `.config` file directly (section 5.2).
|
||||
|
||||
##### 5.1 Enable JerryScript using menuconfig
|
||||
|
||||
```sh
|
||||
# Assuming you are in jerry-nuttx folder.
|
||||
# Might be required to run `make menuconfig` twice.
|
||||
make -C nuttx menuconfig
|
||||
```
|
||||
|
||||
* Enable `System Type -> FPU support`
|
||||
* Enable `Application Configuration -> Interpreters -> JerryScript`
|
||||
|
||||
[Optional] Enabling ROMFS helps to flash JavaScript input files to the device's flash memory.
|
||||
|
||||
* Enable `File systems -> ROMFS file system`
|
||||
* Enable `Application configuration -> NSH library -> Scripting Support -> Support ROMFS start-up script`
|
||||
|
||||
[Optional] Enabling MMCSD helps to mount sd card on the device.
|
||||
Note: These options are for the micro-sd card slot of STM32F4-Discovery base-board.
|
||||
|
||||
* Enable `System Type -> STM32 Peripheral Support -> SDIO`
|
||||
* Enable `RTOS Features -> Work queue support -> High priority (kernel) worker thread`
|
||||
* Enable `RTOS Features -> RTOS hooks -> Custom board late initialization`
|
||||
* Enable `Driver Support -> MMC/SD Driver Support`
|
||||
* Disable `Driver Support -> MMC/SD Driver Support -> MMC/SD write protect pin`
|
||||
* Disable `Driver Support -> MMC/SD Driver Support -> MMC/SD SPI transfer support`
|
||||
* Enable `Driver Support -> MMC/SD Driver Support -> MMC/SD SDIO transfer support`
|
||||
* Enable `File systems -> FAT file system`
|
||||
* Enable `File systems -> FAT file system -> FAT upper/lower names`
|
||||
* Enable `File systems -> FAT file system -> FAT long file names`
|
||||
|
||||
##### 5.2 Enable JerryScript without user interaction
|
||||
|
||||
A simpler solution is to append the necessary content to the `.config` configuration file:
|
||||
|
||||
```sh
|
||||
# Assuming you are in jerry-nuttx folder.
|
||||
cat >> nuttx/.config << EOL
|
||||
CONFIG_ARCH_FPU=y
|
||||
CONFIG_INTERPRETERS_JERRYSCRIPT=y
|
||||
CONFIG_INTERPRETERS_JERRYSCRIPT_PRIORITY=100
|
||||
CONFIG_INTERPRETERS_JERRYSCRIPT_STACKSIZE=16384
|
||||
EOL
|
||||
```
|
||||
|
||||
[Optional] Enable ROM File System
|
||||
|
||||
```sh
|
||||
# Assuming you are in jerry-nuttx folder.
|
||||
cat >> nuttx/.config << EOL
|
||||
CONFIG_BOARDCTL_ROMDISK=y
|
||||
CONFIG_FS_ROMFS=y
|
||||
CONFIG_NSH_ROMFSETC=y
|
||||
CONFIG_NSH_ROMFSMOUNTPT="/etc"
|
||||
CONFIG_NSH_INITSCRIPT="init.d/rcS"
|
||||
CONFIG_NSH_ROMFSDEVNO=0
|
||||
CONFIG_NSH_ROMFSSECTSIZE=64
|
||||
CONFIG_NSH_DEFAULTROMFS=y
|
||||
EOL
|
||||
```
|
||||
|
||||
[Optional] Enable MMCSD driver and FAT File System
|
||||
|
||||
Note: These options are for the micro-sd card slot of STM32F4-Discovery base-board.
|
||||
|
||||
```sh
|
||||
# Assuming you are in jerry-nuttx folder.
|
||||
cat >> nuttx/.config << EOL
|
||||
CONFIG_STM32_SDIO=y
|
||||
CONFIG_STM32_SDIO_DMAPRIO=0x00010000
|
||||
CONFIG_MMCSD_HAVE_CARDDETECT=y
|
||||
CONFIG_BOARD_LATE_INITIALIZE=y
|
||||
CONFIG_BOARD_INITTHREAD_STACKSIZE=2048
|
||||
CONFIG_BOARD_INITTHREAD_PRIORITY=240
|
||||
CONFIG_SIG_SIGWORK=17
|
||||
CONFIG_SCHED_WORKQUEUE=y
|
||||
CONFIG_SCHED_HPWORK=y
|
||||
CONFIG_SCHED_HPNTHREADS=1
|
||||
CONFIG_SCHED_HPWORKPRIORITY=224
|
||||
CONFIG_SCHED_HPWORKSTACKSIZE=2048
|
||||
CONFIG_BCH=y
|
||||
CONFIG_ARCH_HAVE_SDIO=y
|
||||
CONFIG_ARCH_HAVE_SDIOWAIT_WRCOMPLETE=y
|
||||
CONFIG_ARCH_HAVE_SDIO_PREFLIGHT=y
|
||||
CONFIG_MMCSD=y
|
||||
CONFIG_MMCSD_NSLOTS=1
|
||||
CONFIG_MMCSD_MMCSUPPORT=y
|
||||
CONFIG_MMCSD_SDIO=y
|
||||
CONFIG_FS_FAT=y
|
||||
CONFIG_FAT_LCNAMES=y
|
||||
CONFIG_FAT_LFN=y
|
||||
CONFIG_FAT_MAXFNAME=32
|
||||
CONFIG_FAT_LFN_ALIAS_TRAILCHARS=0
|
||||
CONFIG_FSUTILS_MKFATFS=y
|
||||
CONFIG_NSH_MMCSDSLOTNO=0
|
||||
EOL
|
||||
```
|
||||
|
||||
#### 6. Provide JavaScript files for STM32F4 device
|
||||
|
||||
##### 6.1. Create ROMFS image from a custom folder
|
||||
|
||||
Skip this section if MMCSD is used. Otherwise, generate a C header file from a custom folder.
|
||||
Try to minimize the size of the folder due to the limited capacity of flash memory.
|
||||
|
||||
```sh
|
||||
# Assuming you are in jerry-nuttx folder.
|
||||
mkdir jerry-example
|
||||
# Let hello.js be a possible JavaScript input for JerryScript.
|
||||
cp jerryscript/tests/hello.js jerry-example
|
||||
|
||||
# Generate ROMFS image from a custom folder.
|
||||
genromfs -f romfs_img -d jerry-example
|
||||
|
||||
# Dump image as C header file and override NuttX's default ROMFS file.
|
||||
xxd -i romfs_img apps/nshlib/nsh_romfsimg.h
|
||||
|
||||
# Add const modifier to place the content to flash memory.
|
||||
sed -i "s/unsigned/const\ unsigned/g" apps/nshlib/nsh_romfsimg.h
|
||||
```
|
||||
|
||||
##### 6.2. Copy files to memory card
|
||||
|
||||
Skip this section if ROMFS is used. Otherwise, copy your files to a FAT32 formatted memory card.
|
||||
|
||||
#### 7. Build NuttX (with JerryScript)
|
||||
|
||||
```sh
|
||||
# Assuming you are in jerry-nuttx folder.
|
||||
make -C nuttx
|
||||
```
|
||||
|
||||
#### 8. Flash the device
|
||||
|
||||
Connect Mini-USB for charging and flasing the device.
|
||||
|
||||
```sh
|
||||
# Assuming you are in jerry-nuttx folder.
|
||||
make -C stlink release
|
||||
|
||||
sudo stlink/build/Release/st-flash write nuttx/nuttx.bin 0x8000000
|
||||
```
|
||||
|
||||
#### 9. Connect to the device
|
||||
|
||||
Connect Micro-USB for serial communication. The device should be visible as `/dev/ttyACM0` on the host.
|
||||
You can use `minicom` communication program with `115200` baud rate.
|
||||
|
||||
```sh
|
||||
sudo minicom --device=/dev/ttyACM0 --baud=115200
|
||||
```
|
||||
|
||||
Set `Add Carriage Ret` option in `minicom` by `CTRL-A -> Z -> U` key combinations.
|
||||
You may have to press `RESET` on the board and press `Enter` key on the console several times to make `nsh` prompt visible.
|
||||
NuttShell (NSH) prompt looks like as follows:
|
||||
|
||||
```
|
||||
NuttShell (NSH) NuttX-10.2.0
|
||||
nsh>
|
||||
```
|
||||
|
||||
#### 10. Run JerryScript
|
||||
|
||||
##### 10.1 Run `jerry` without input
|
||||
|
||||
```
|
||||
NuttShell (NSH) NuttX-10.2.0
|
||||
nsh> jerry
|
||||
No input files, running a hello world demo:
|
||||
Hello world 5 times from JerryScript
|
||||
```
|
||||
|
||||
##### 10.2 Run `jerry` with files from ROMFS
|
||||
|
||||
```
|
||||
NuttShell (NSH) NuttX-10.2.0
|
||||
nsh> jerry /etc/hello.js
|
||||
```
|
||||
|
||||
##### 10.3 Run `jerry` with files from memory card
|
||||
|
||||
After NuttX has initialized, the card reader should be visible as `/dev/mmcsd0` on the device.
|
||||
Mount it to be JavaScript files reachable.
|
||||
|
||||
```
|
||||
NuttShell (NSH) NuttX-10.2.0
|
||||
nsh> mount -t vfat /dev/mmcsd0 /mnt
|
||||
nsh> jerry /mnt/hello.js
|
||||
```
|
||||
@@ -0,0 +1,450 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include <assert.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
|
||||
#include "jerryscript-port.h"
|
||||
#include "jerryscript.h"
|
||||
|
||||
#include "jerryscript-ext/debugger.h"
|
||||
#include "jerryscript-ext/handler.h"
|
||||
#include "setjmp.h"
|
||||
|
||||
/**
|
||||
* Maximum command line arguments number.
|
||||
*/
|
||||
#define JERRY_MAX_COMMAND_LINE_ARGS (16)
|
||||
|
||||
/**
|
||||
* Standalone Jerry exit codes.
|
||||
*/
|
||||
#define JERRY_STANDALONE_EXIT_CODE_OK (0)
|
||||
#define JERRY_STANDALONE_EXIT_CODE_FAIL (1)
|
||||
|
||||
/**
|
||||
* Context size of the SYNTAX_ERROR
|
||||
*/
|
||||
#define SYNTAX_ERROR_CONTEXT_SIZE 2
|
||||
|
||||
void set_log_level (jerry_log_level_t level);
|
||||
|
||||
/**
|
||||
* Print usage and available options
|
||||
*/
|
||||
static void
|
||||
print_help (char *name)
|
||||
{
|
||||
printf ("Usage: %s [OPTION]... [FILE]...\n"
|
||||
"\n"
|
||||
"Options:\n"
|
||||
" --log-level [0-3]\n"
|
||||
" --mem-stats\n"
|
||||
" --mem-stats-separate\n"
|
||||
" --show-opcodes\n"
|
||||
" --start-debug-server\n"
|
||||
" --debug-server-port [port]\n"
|
||||
"\n",
|
||||
name);
|
||||
} /* print_help */
|
||||
|
||||
/**
|
||||
* Read source code into buffer.
|
||||
*
|
||||
* Returned value must be freed with jmem_heap_free_block if it's not NULL.
|
||||
* @return NULL, if read or allocation has failed
|
||||
* pointer to the allocated memory block, otherwise
|
||||
*/
|
||||
static const uint8_t *
|
||||
read_file (const char *file_name, /**< source code */
|
||||
size_t *out_size_p) /**< [out] number of bytes successfully read from source */
|
||||
{
|
||||
FILE *file = fopen (file_name, "r");
|
||||
if (file == NULL)
|
||||
{
|
||||
jerry_port_log (JERRY_LOG_LEVEL_ERROR, "Error: cannot open file: %s\n", file_name);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
int fseek_status = fseek (file, 0, SEEK_END);
|
||||
if (fseek_status != 0)
|
||||
{
|
||||
jerry_port_log (JERRY_LOG_LEVEL_ERROR, "Failed to seek (error: %d)\n", fseek_status);
|
||||
fclose (file);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
long script_len = ftell (file);
|
||||
if (script_len < 0)
|
||||
{
|
||||
jerry_port_log (JERRY_LOG_LEVEL_ERROR, "Failed to get the file size(error %ld)\n", script_len);
|
||||
fclose (file);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
rewind (file);
|
||||
|
||||
uint8_t *buffer = (uint8_t *) malloc (script_len);
|
||||
|
||||
if (buffer == NULL)
|
||||
{
|
||||
jerry_port_log (JERRY_LOG_LEVEL_ERROR, "Out of memory error\n");
|
||||
fclose (file);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
size_t bytes_read = fread (buffer, 1u, script_len, file);
|
||||
|
||||
if (!bytes_read || bytes_read != script_len)
|
||||
{
|
||||
jerry_port_log (JERRY_LOG_LEVEL_ERROR, "Error: failed to read file: %s\n", file_name);
|
||||
free ((void *) buffer);
|
||||
|
||||
fclose (file);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
fclose (file);
|
||||
|
||||
*out_size_p = bytes_read;
|
||||
return (const uint8_t *) buffer;
|
||||
} /* read_file */
|
||||
|
||||
/**
|
||||
* Convert string into unsigned integer
|
||||
*
|
||||
* @return converted number
|
||||
*/
|
||||
static uint32_t
|
||||
str_to_uint (const char *num_str_p, /**< string to convert */
|
||||
char **out_p) /**< [out] end of the number */
|
||||
{
|
||||
assert (jerry_feature_enabled (JERRY_FEATURE_ERROR_MESSAGES));
|
||||
|
||||
uint32_t result = 0;
|
||||
|
||||
while (*num_str_p >= '0' && *num_str_p <= '9')
|
||||
{
|
||||
result *= 10;
|
||||
result += (uint32_t) (*num_str_p - '0');
|
||||
num_str_p++;
|
||||
}
|
||||
|
||||
if (out_p != NULL)
|
||||
{
|
||||
*out_p = num_str_p;
|
||||
}
|
||||
|
||||
return result;
|
||||
} /* str_to_uint */
|
||||
|
||||
/**
|
||||
* Print error value
|
||||
*/
|
||||
static void
|
||||
print_unhandled_exception (jerry_value_t error_value) /**< error value */
|
||||
{
|
||||
assert (jerry_value_is_exception (error_value));
|
||||
|
||||
error_value = jerry_exception_value (error_value, false);
|
||||
jerry_value_t err_str_val = jerry_value_to_string (error_value);
|
||||
jerry_char_t err_str_buf[256];
|
||||
|
||||
jerry_value_free (error_value);
|
||||
|
||||
jerry_size_t sz = jerry_string_to_buffer (err_str_val, JERRY_ENCODING_UTF8, err_str_buf, sizeof (err_str_buf) - 1);
|
||||
err_str_buf[sz] = '\0';
|
||||
|
||||
if (jerry_feature_enabled (JERRY_FEATURE_ERROR_MESSAGES) && jerry_error_type (error_value) == JERRY_ERROR_SYNTAX)
|
||||
{
|
||||
jerry_char_t *string_end_p = err_str_buf + sz;
|
||||
uint32_t err_line = 0;
|
||||
uint32_t err_col = 0;
|
||||
char *path_str_p = NULL;
|
||||
char *path_str_end_p = NULL;
|
||||
|
||||
/* 1. parse column and line information */
|
||||
for (jerry_char_t *current_p = err_str_buf; current_p < string_end_p; current_p++)
|
||||
{
|
||||
if (*current_p == '[')
|
||||
{
|
||||
current_p++;
|
||||
|
||||
if (*current_p == '<')
|
||||
{
|
||||
break;
|
||||
}
|
||||
|
||||
path_str_p = (char *) current_p;
|
||||
while (current_p < string_end_p && *current_p != ':')
|
||||
{
|
||||
current_p++;
|
||||
}
|
||||
|
||||
path_str_end_p = (char *) current_p++;
|
||||
|
||||
err_line = str_to_uint ((char *) current_p, (char **) ¤t_p);
|
||||
|
||||
current_p++;
|
||||
|
||||
err_col = str_to_uint ((char *) current_p, NULL);
|
||||
break;
|
||||
}
|
||||
} /* for */
|
||||
|
||||
if (err_line != 0 && err_col != 0)
|
||||
{
|
||||
uint32_t curr_line = 1;
|
||||
|
||||
bool is_printing_context = false;
|
||||
uint32_t pos = 0;
|
||||
|
||||
/* Temporarily modify the error message, so we can use the path. */
|
||||
*path_str_end_p = '\0';
|
||||
|
||||
size_t source_size;
|
||||
const jerry_char_t *source_p = read_file (path_str_p, &source_size);
|
||||
|
||||
/* Revert the error message. */
|
||||
*path_str_end_p = ':';
|
||||
|
||||
/* 2. seek and print */
|
||||
while (source_p[pos] != '\0')
|
||||
{
|
||||
if (source_p[pos] == '\n')
|
||||
{
|
||||
curr_line++;
|
||||
}
|
||||
|
||||
if (err_line < SYNTAX_ERROR_CONTEXT_SIZE
|
||||
|| (err_line >= curr_line && (err_line - curr_line) <= SYNTAX_ERROR_CONTEXT_SIZE))
|
||||
{
|
||||
/* context must be printed */
|
||||
is_printing_context = true;
|
||||
}
|
||||
|
||||
if (curr_line > err_line)
|
||||
{
|
||||
break;
|
||||
}
|
||||
|
||||
if (is_printing_context)
|
||||
{
|
||||
jerry_port_log (JERRY_LOG_LEVEL_ERROR, "%c", source_p[pos]);
|
||||
}
|
||||
|
||||
pos++;
|
||||
}
|
||||
|
||||
jerry_port_log (JERRY_LOG_LEVEL_ERROR, "\n");
|
||||
|
||||
while (--err_col)
|
||||
{
|
||||
jerry_port_log (JERRY_LOG_LEVEL_ERROR, "~");
|
||||
}
|
||||
|
||||
jerry_port_log (JERRY_LOG_LEVEL_ERROR, "^\n");
|
||||
}
|
||||
}
|
||||
|
||||
jerry_port_log (JERRY_LOG_LEVEL_ERROR, "Script Error: %s\n", err_str_buf);
|
||||
jerry_value_free (err_str_val);
|
||||
} /* print_unhandled_exception */
|
||||
|
||||
/**
|
||||
* Register a JavaScript function in the global object.
|
||||
*/
|
||||
static void
|
||||
register_js_function (const char *name_p, /**< name of the function */
|
||||
jerry_external_handler_t handler_p) /**< function callback */
|
||||
{
|
||||
jerry_value_t result_val = jerryx_handler_register_global (name_p, handler_p);
|
||||
|
||||
if (jerry_value_is_exception (result_val))
|
||||
{
|
||||
jerry_port_log (JERRY_LOG_LEVEL_WARNING, "Warning: failed to register '%s' method.", name_p);
|
||||
}
|
||||
|
||||
jerry_value_free (result_val);
|
||||
} /* register_js_function */
|
||||
|
||||
/**
|
||||
* Main program.
|
||||
*
|
||||
* @return 0 if success, error code otherwise
|
||||
*/
|
||||
#ifdef CONFIG_BUILD_KERNEL
|
||||
int
|
||||
main (int argc, FAR char *argv[])
|
||||
#else /* !defined(CONFIG_BUILD_KERNEL) */
|
||||
int
|
||||
jerry_main (int argc, char *argv[])
|
||||
#endif /* defined(CONFIG_BUILD_KERNEL) */
|
||||
{
|
||||
if (argc > JERRY_MAX_COMMAND_LINE_ARGS)
|
||||
{
|
||||
jerry_port_log (JERRY_LOG_LEVEL_ERROR,
|
||||
"Too many command line arguments. Current maximum is %d\n",
|
||||
JERRY_MAX_COMMAND_LINE_ARGS);
|
||||
|
||||
return JERRY_STANDALONE_EXIT_CODE_FAIL;
|
||||
}
|
||||
|
||||
const char *file_names[JERRY_MAX_COMMAND_LINE_ARGS];
|
||||
int i;
|
||||
int files_counter = 0;
|
||||
bool start_debug_server = false;
|
||||
uint16_t debug_port = 5001;
|
||||
|
||||
jerry_init_flag_t flags = JERRY_INIT_EMPTY;
|
||||
|
||||
for (i = 1; i < argc; i++)
|
||||
{
|
||||
if (!strcmp ("-h", argv[i]) || !strcmp ("--help", argv[i]))
|
||||
{
|
||||
print_help (argv[0]);
|
||||
return JERRY_STANDALONE_EXIT_CODE_OK;
|
||||
}
|
||||
else if (!strcmp ("--mem-stats", argv[i]))
|
||||
{
|
||||
flags |= JERRY_INIT_MEM_STATS;
|
||||
set_log_level (JERRY_LOG_LEVEL_DEBUG);
|
||||
}
|
||||
else if (!strcmp ("--show-opcodes", argv[i]))
|
||||
{
|
||||
flags |= JERRY_INIT_SHOW_OPCODES | JERRY_INIT_SHOW_REGEXP_OPCODES;
|
||||
set_log_level (JERRY_LOG_LEVEL_DEBUG);
|
||||
}
|
||||
else if (!strcmp ("--log-level", argv[i]))
|
||||
{
|
||||
if (++i < argc && strlen (argv[i]) == 1 && argv[i][0] >= '0' && argv[i][0] <= '3')
|
||||
{
|
||||
set_log_level (argv[i][0] - '0');
|
||||
}
|
||||
else
|
||||
{
|
||||
jerry_port_log (JERRY_LOG_LEVEL_ERROR, "Error: wrong format or invalid argument\n");
|
||||
return JERRY_STANDALONE_EXIT_CODE_FAIL;
|
||||
}
|
||||
}
|
||||
else if (!strcmp ("--start-debug-server", argv[i]))
|
||||
{
|
||||
start_debug_server = true;
|
||||
}
|
||||
else if (!strcmp ("--debug-server-port", argv[i]))
|
||||
{
|
||||
if (++i < argc)
|
||||
{
|
||||
debug_port = str_to_uint (argv[i], NULL);
|
||||
}
|
||||
else
|
||||
{
|
||||
jerry_port_log (JERRY_LOG_LEVEL_ERROR, "Error: wrong format or invalid argument\n");
|
||||
return JERRY_STANDALONE_EXIT_CODE_FAIL;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
file_names[files_counter++] = argv[i];
|
||||
}
|
||||
}
|
||||
|
||||
jerry_init (flags);
|
||||
|
||||
if (start_debug_server)
|
||||
{
|
||||
jerryx_debugger_after_connect (jerryx_debugger_tcp_create (debug_port) && jerryx_debugger_ws_create ());
|
||||
}
|
||||
|
||||
register_js_function ("assert", jerryx_handler_assert);
|
||||
register_js_function ("gc", jerryx_handler_gc);
|
||||
register_js_function ("print", jerryx_handler_print);
|
||||
|
||||
jerry_value_t ret_value = jerry_undefined ();
|
||||
|
||||
if (files_counter == 0)
|
||||
{
|
||||
printf ("No input files, running a hello world demo:\n");
|
||||
const jerry_char_t script[] = "var str = 'Hello World'; print(str + ' from JerryScript')";
|
||||
|
||||
ret_value = jerry_parse (script, sizeof (script) - 1, NULL);
|
||||
|
||||
if (!jerry_value_is_exception (ret_value))
|
||||
{
|
||||
ret_value = jerry_run (ret_value);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
for (i = 0; i < files_counter; i++)
|
||||
{
|
||||
size_t source_size;
|
||||
const jerry_char_t *source_p = read_file (file_names[i], &source_size);
|
||||
|
||||
if (source_p == NULL)
|
||||
{
|
||||
jerry_port_log (JERRY_LOG_LEVEL_ERROR, "Source file load error\n");
|
||||
return JERRY_STANDALONE_EXIT_CODE_FAIL;
|
||||
}
|
||||
|
||||
jerry_parse_options_t parse_options;
|
||||
parse_options.options = JERRY_PARSE_HAS_SOURCE_NAME;
|
||||
parse_options.source_name = jerry_string_sz (file_names[i]);
|
||||
|
||||
ret_value = jerry_parse (source_p, source_size, &parse_options);
|
||||
jerry_value_free (parse_options.source_name);
|
||||
free ((void *) source_p);
|
||||
|
||||
if (!jerry_value_is_exception (ret_value))
|
||||
{
|
||||
jerry_value_t func_val = ret_value;
|
||||
ret_value = jerry_run (func_val);
|
||||
jerry_value_free (func_val);
|
||||
}
|
||||
|
||||
if (jerry_value_is_exception (ret_value))
|
||||
{
|
||||
print_unhandled_exception (ret_value);
|
||||
break;
|
||||
}
|
||||
|
||||
jerry_value_free (ret_value);
|
||||
ret_value = jerry_undefined ();
|
||||
}
|
||||
}
|
||||
|
||||
int ret_code = JERRY_STANDALONE_EXIT_CODE_OK;
|
||||
|
||||
if (jerry_value_is_exception (ret_value))
|
||||
{
|
||||
ret_code = JERRY_STANDALONE_EXIT_CODE_FAIL;
|
||||
}
|
||||
|
||||
jerry_value_free (ret_value);
|
||||
|
||||
ret_value = jerry_run_jobs ();
|
||||
|
||||
if (jerry_value_is_exception (ret_value))
|
||||
{
|
||||
ret_code = JERRY_STANDALONE_EXIT_CODE_FAIL;
|
||||
}
|
||||
|
||||
jerry_value_free (ret_value);
|
||||
jerry_cleanup ();
|
||||
|
||||
return ret_code;
|
||||
} /* main */
|
||||
@@ -0,0 +1,294 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#include "jerryscript-port.h"
|
||||
#include "jerryscript.h"
|
||||
|
||||
/**
|
||||
* Computes the end of the directory part of a path.
|
||||
*
|
||||
* @return end of the directory part of a path.
|
||||
*/
|
||||
static size_t
|
||||
jerry_port_get_directory_end (const jerry_char_t *path_p) /**< path */
|
||||
{
|
||||
const jerry_char_t *end_p = path_p + strlen ((const char *) path_p);
|
||||
|
||||
while (end_p > path_p)
|
||||
{
|
||||
if (end_p[-1] == '/')
|
||||
{
|
||||
return (size_t) (end_p - path_p);
|
||||
}
|
||||
|
||||
end_p--;
|
||||
}
|
||||
|
||||
return 0;
|
||||
} /* jerry_port_get_directory_end */
|
||||
|
||||
/**
|
||||
* Normalize a file path.
|
||||
*
|
||||
* @return a newly allocated buffer with the normalized path if the operation is successful,
|
||||
* NULL otherwise
|
||||
*/
|
||||
static jerry_char_t *
|
||||
jerry_port_normalize_path (const jerry_char_t *in_path_p, /**< path to the referenced module */
|
||||
size_t in_path_length, /**< length of the path */
|
||||
const jerry_char_t *base_path_p, /**< base path */
|
||||
size_t base_path_length) /**< length of the base path */
|
||||
{
|
||||
char *path_p;
|
||||
|
||||
if (base_path_length > 0)
|
||||
{
|
||||
path_p = (char *) malloc (base_path_length + in_path_length + 1);
|
||||
|
||||
if (path_p == NULL)
|
||||
{
|
||||
return NULL;
|
||||
}
|
||||
|
||||
memcpy (path_p, base_path_p, base_path_length);
|
||||
memcpy (path_p + base_path_length, in_path_p, in_path_length);
|
||||
path_p[base_path_length + in_path_length] = '\0';
|
||||
}
|
||||
else
|
||||
{
|
||||
path_p = (char *) malloc (in_path_length + 1);
|
||||
|
||||
if (path_p == NULL)
|
||||
{
|
||||
return NULL;
|
||||
}
|
||||
|
||||
memcpy (path_p, in_path_p, in_path_length);
|
||||
path_p[in_path_length] = '\0';
|
||||
}
|
||||
|
||||
return (jerry_char_t *) path_p;
|
||||
} /* jerry_port_normalize_path */
|
||||
|
||||
/**
|
||||
* A module descriptor.
|
||||
*/
|
||||
typedef struct jerry_port_module_t
|
||||
{
|
||||
struct jerry_port_module_t *next_p; /**< next_module */
|
||||
jerry_char_t *path_p; /**< path to the module */
|
||||
size_t base_path_length; /**< base path length for relative difference */
|
||||
jerry_value_t realm; /**< the realm of the module */
|
||||
jerry_value_t module; /**< the module itself */
|
||||
} jerry_port_module_t;
|
||||
|
||||
/**
|
||||
* Native info descriptor for modules.
|
||||
*/
|
||||
static const jerry_object_native_info_t jerry_port_module_native_info = {
|
||||
.free_cb = NULL,
|
||||
};
|
||||
|
||||
/**
|
||||
* Default module manager.
|
||||
*/
|
||||
typedef struct
|
||||
{
|
||||
jerry_port_module_t *module_head_p; /**< first module */
|
||||
} jerry_port_module_manager_t;
|
||||
|
||||
/**
|
||||
* Release known modules.
|
||||
*/
|
||||
static void
|
||||
jerry_port_module_free (jerry_port_module_manager_t *manager_p, /**< module manager */
|
||||
const jerry_value_t realm) /**< if this argument is object, release only those modules,
|
||||
* which realm value is equal to this argument. */
|
||||
{
|
||||
jerry_port_module_t *module_p = manager_p->module_head_p;
|
||||
|
||||
bool release_all = !jerry_value_is_object (realm);
|
||||
|
||||
jerry_port_module_t *prev_p = NULL;
|
||||
|
||||
while (module_p != NULL)
|
||||
{
|
||||
jerry_port_module_t *next_p = module_p->next_p;
|
||||
|
||||
if (release_all || module_p->realm == realm)
|
||||
{
|
||||
free (module_p->path_p);
|
||||
jerry_value_free (module_p->realm);
|
||||
jerry_value_free (module_p->module);
|
||||
|
||||
free (module_p);
|
||||
|
||||
if (prev_p == NULL)
|
||||
{
|
||||
manager_p->module_head_p = next_p;
|
||||
}
|
||||
else
|
||||
{
|
||||
prev_p->next_p = next_p;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
prev_p = module_p;
|
||||
}
|
||||
|
||||
module_p = next_p;
|
||||
}
|
||||
} /* jerry_port_module_free */
|
||||
|
||||
/**
|
||||
* Initialize the default module manager.
|
||||
*/
|
||||
static void
|
||||
jerry_port_module_manager_init (void *user_data_p)
|
||||
{
|
||||
((jerry_port_module_manager_t *) user_data_p)->module_head_p = NULL;
|
||||
} /* jerry_port_module_manager_init */
|
||||
|
||||
/**
|
||||
* Deinitialize the default module manager.
|
||||
*/
|
||||
static void
|
||||
jerry_port_module_manager_deinit (void *user_data_p) /**< context pointer to deinitialize */
|
||||
{
|
||||
jerry_value_t undef = jerry_undefined ();
|
||||
jerry_port_module_free ((jerry_port_module_manager_t *) user_data_p, undef);
|
||||
jerry_value_free (undef);
|
||||
} /* jerry_port_module_manager_deinit */
|
||||
|
||||
/**
|
||||
* Declare the context data manager for modules.
|
||||
*/
|
||||
static const jerry_context_data_manager_t jerry_port_module_manager = { .init_cb = jerry_port_module_manager_init,
|
||||
.deinit_cb = jerry_port_module_manager_deinit,
|
||||
.bytes_needed =
|
||||
sizeof (jerry_port_module_manager_t) };
|
||||
|
||||
/**
|
||||
* Default module resolver.
|
||||
*
|
||||
* @return a module object if resolving is successful, an error otherwise
|
||||
*/
|
||||
jerry_value_t
|
||||
jerry_port_module_resolve (const jerry_value_t specifier, /**< module specifier string */
|
||||
const jerry_value_t referrer, /**< parent module */
|
||||
void *user_p) /**< user data */
|
||||
{
|
||||
(void) user_p;
|
||||
|
||||
const jerry_char_t *base_path_p = NULL;
|
||||
size_t base_path_length = 0;
|
||||
jerry_port_module_t *module_p = jerry_object_get_native_ptr (referrer, &jerry_port_module_native_info);
|
||||
|
||||
if (module_p != NULL)
|
||||
{
|
||||
base_path_p = module_p->path_p;
|
||||
base_path_length = module_p->base_path_length;
|
||||
}
|
||||
|
||||
jerry_size_t in_path_length = jerry_string_size (specifier, JERRY_ENCODING_UTF8);
|
||||
jerry_char_t *in_path_p = (jerry_char_t *) malloc (in_path_length + 1);
|
||||
jerry_string_to_buffer (specifier, JERRY_ENCODING_UTF8, in_path_p, in_path_length);
|
||||
in_path_p[in_path_length] = '\0';
|
||||
|
||||
jerry_char_t *path_p = jerry_port_normalize_path (in_path_p, in_path_length, base_path_p, base_path_length);
|
||||
|
||||
if (path_p == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_COMMON, "Out of memory");
|
||||
}
|
||||
|
||||
jerry_value_t realm = jerry_current_realm ();
|
||||
|
||||
jerry_port_module_manager_t *manager_p;
|
||||
manager_p = (jerry_port_module_manager_t *) jerry_context_data (&jerry_port_module_manager);
|
||||
|
||||
module_p = manager_p->module_head_p;
|
||||
|
||||
while (module_p != NULL)
|
||||
{
|
||||
if (module_p->realm == realm && strcmp ((const char *) module_p->path_p, (const char *) path_p) == 0)
|
||||
{
|
||||
free (path_p);
|
||||
free (in_path_p);
|
||||
jerry_value_free (realm);
|
||||
return jerry_value_copy (module_p->module);
|
||||
}
|
||||
|
||||
module_p = module_p->next_p;
|
||||
}
|
||||
|
||||
size_t source_size;
|
||||
uint8_t *source_p = jerry_port_read_source ((const char *) path_p, &source_size);
|
||||
|
||||
if (source_p == NULL)
|
||||
{
|
||||
free (path_p);
|
||||
free (in_path_p);
|
||||
jerry_value_free (realm);
|
||||
|
||||
return jerry_throw_sz (JERRY_ERROR_SYNTAX, "Module file not found");
|
||||
}
|
||||
|
||||
jerry_parse_options_t parse_options;
|
||||
parse_options.options = JERRY_PARSE_MODULE | JERRY_PARSE_HAS_SOURCE_NAME;
|
||||
parse_options.source_name = jerry_string (in_path_p, in_path_length, JERRY_ENCODING_UTF8);
|
||||
|
||||
jerry_value_t ret_value = jerry_parse (source_p, source_size, &parse_options);
|
||||
|
||||
jerry_value_free (parse_options.source_name);
|
||||
jerry_port_release_source (source_p);
|
||||
free (in_path_p);
|
||||
|
||||
if (jerry_value_is_exception (ret_value))
|
||||
{
|
||||
free (path_p);
|
||||
jerry_value_free (realm);
|
||||
return ret_value;
|
||||
}
|
||||
|
||||
module_p = (jerry_port_module_t *) malloc (sizeof (jerry_port_module_t));
|
||||
|
||||
module_p->next_p = manager_p->module_head_p;
|
||||
module_p->path_p = path_p;
|
||||
module_p->base_path_length = jerry_port_get_directory_end (module_p->path_p);
|
||||
module_p->realm = realm;
|
||||
module_p->module = jerry_value_copy (ret_value);
|
||||
|
||||
jerry_object_set_native_ptr (ret_value, &jerry_port_module_native_info, module_p);
|
||||
manager_p->module_head_p = module_p;
|
||||
|
||||
return ret_value;
|
||||
} /* jerry_port_module_resolve */
|
||||
|
||||
/**
|
||||
* Release known modules.
|
||||
*/
|
||||
void
|
||||
jerry_port_module_release (const jerry_value_t realm) /**< if this argument is object, release only those modules,
|
||||
* which realm value is equal to this argument. */
|
||||
{
|
||||
jerry_port_module_free ((jerry_port_module_manager_t *) jerry_context_data (&jerry_port_module_manager), realm);
|
||||
} /* jerry_port_module_release */
|
||||
@@ -0,0 +1,193 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include <stdlib.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#include "jerryscript.h"
|
||||
#include "jerryscript-port.h"
|
||||
|
||||
/**
|
||||
* JerryScript log level
|
||||
*/
|
||||
static jerry_log_level_t jerry_log_level = JERRY_LOG_LEVEL_ERROR;
|
||||
|
||||
/**
|
||||
* Sets log level.
|
||||
*/
|
||||
void set_log_level (jerry_log_level_t level)
|
||||
{
|
||||
jerry_log_level = level;
|
||||
} /* set_log_level */
|
||||
|
||||
/**
|
||||
* Aborts the program.
|
||||
*/
|
||||
void jerry_port_fatal (jerry_fatal_code_t code)
|
||||
{
|
||||
exit (1);
|
||||
} /* jerry_port_fatal */
|
||||
|
||||
/**
|
||||
* Provide log message implementation for the engine.
|
||||
*/
|
||||
void
|
||||
jerry_port_log (jerry_log_level_t level, /**< log level */
|
||||
const char *format, /**< format string */
|
||||
...) /**< parameters */
|
||||
{
|
||||
if (level <= jerry_log_level)
|
||||
{
|
||||
va_list args;
|
||||
va_start (args, format);
|
||||
vfprintf (stderr, format, args);
|
||||
va_end (args);
|
||||
}
|
||||
} /* jerry_port_log */
|
||||
|
||||
/**
|
||||
* Determines the size of the given file.
|
||||
* @return size of the file
|
||||
*/
|
||||
static size_t
|
||||
jerry_port_get_file_size (FILE *file_p) /**< opened file */
|
||||
{
|
||||
fseek (file_p, 0, SEEK_END);
|
||||
long size = ftell (file_p);
|
||||
fseek (file_p, 0, SEEK_SET);
|
||||
|
||||
return (size_t) size;
|
||||
} /* jerry_port_get_file_size */
|
||||
|
||||
/**
|
||||
* Opens file with the given path and reads its source.
|
||||
* @return the source of the file
|
||||
*/
|
||||
uint8_t *
|
||||
jerry_port_read_source (const char *file_name_p, /**< file name */
|
||||
size_t *out_size_p) /**< [out] read bytes */
|
||||
{
|
||||
FILE *file_p = fopen (file_name_p, "rb");
|
||||
|
||||
if (file_p == NULL)
|
||||
{
|
||||
jerry_port_log (JERRY_LOG_LEVEL_ERROR, "Error: failed to open file: %s\n", file_name_p);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
size_t file_size = jerry_port_get_file_size (file_p);
|
||||
uint8_t *buffer_p = (uint8_t *) malloc (file_size);
|
||||
|
||||
if (buffer_p == NULL)
|
||||
{
|
||||
fclose (file_p);
|
||||
|
||||
jerry_port_log (JERRY_LOG_LEVEL_ERROR, "Error: failed to allocate memory for module");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
size_t bytes_read = fread (buffer_p, 1u, file_size, file_p);
|
||||
|
||||
if (!bytes_read)
|
||||
{
|
||||
fclose (file_p);
|
||||
free (buffer_p);
|
||||
|
||||
jerry_port_log (JERRY_LOG_LEVEL_ERROR, "Error: failed to read file: %s\n", file_name_p);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
fclose (file_p);
|
||||
*out_size_p = bytes_read;
|
||||
|
||||
return buffer_p;
|
||||
} /* jerry_port_read_source */
|
||||
|
||||
/**
|
||||
* Release the previously opened file's content.
|
||||
*/
|
||||
void
|
||||
jerry_port_release_source (uint8_t *buffer_p) /**< buffer to free */
|
||||
{
|
||||
free (buffer_p);
|
||||
} /* jerry_port_release_source */
|
||||
|
||||
/**
|
||||
* Dummy function to get the time zone adjustment.
|
||||
*
|
||||
* @return 0
|
||||
*/
|
||||
double
|
||||
jerry_port_get_local_time_zone_adjustment (double unix_ms, bool is_utc)
|
||||
{
|
||||
/* We live in UTC. */
|
||||
return 0;
|
||||
} /* jerry_port_get_local_time_zone_adjustment */
|
||||
|
||||
/**
|
||||
* Dummy function to get the current time.
|
||||
*
|
||||
* @return 0
|
||||
*/
|
||||
double
|
||||
jerry_port_get_current_time (void)
|
||||
{
|
||||
return 0;
|
||||
} /* jerry_port_get_current_time */
|
||||
|
||||
/**
|
||||
* Provide the implementation of jerry_port_print_char.
|
||||
* Uses 'printf' to print a single character to standard output.
|
||||
*/
|
||||
void
|
||||
jerry_port_print_char (char c) /**< the character to print */
|
||||
{
|
||||
printf ("%c", c);
|
||||
} /* jerry_port_print_char */
|
||||
|
||||
/**
|
||||
* Provide implementation of jerry_port_sleep.
|
||||
*/
|
||||
void jerry_port_sleep (uint32_t sleep_time) /**< milliseconds to sleep */
|
||||
{
|
||||
usleep ((useconds_t) sleep_time * 1000);
|
||||
} /* jerry_port_sleep */
|
||||
|
||||
/**
|
||||
* Pointer to the current context.
|
||||
*/
|
||||
static jerry_context_t *current_context_p = NULL;
|
||||
|
||||
/**
|
||||
* Set the current_context_p as the passed pointer.
|
||||
*/
|
||||
void
|
||||
jerry_port_default_set_current_context (jerry_context_t *context_p) /**< points to the created context */
|
||||
{
|
||||
current_context_p = context_p;
|
||||
} /* jerry_port_default_set_current_context */
|
||||
|
||||
/**
|
||||
* Get the current context.
|
||||
*
|
||||
* @return the pointer to the current context
|
||||
*/
|
||||
jerry_context_t *
|
||||
jerry_port_get_current_context (void)
|
||||
{
|
||||
return current_context_p;
|
||||
} /* jerry_port_get_current_context */
|
||||
@@ -0,0 +1,65 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
.syntax unified
|
||||
|
||||
.macro func _name
|
||||
.global \_name
|
||||
.type \_name, %function
|
||||
\_name:
|
||||
.endm
|
||||
.macro endfunc _name
|
||||
.size \_name, .-\_name
|
||||
.endm
|
||||
|
||||
/**
|
||||
* setjmp (jmp_buf env)
|
||||
*
|
||||
* See also:
|
||||
* longjmp
|
||||
*
|
||||
* @return 0 - if returns from direct call,
|
||||
* nonzero - if returns after longjmp.
|
||||
*/
|
||||
func setjmp
|
||||
stmia r0!, {r4 - r11, lr}
|
||||
str sp, [r0], #4
|
||||
vstm r0, {s16 - s31}
|
||||
mov r0, #0
|
||||
bx lr
|
||||
endfunc setjmp
|
||||
|
||||
/**
|
||||
* longjmp (jmp_buf env, int val)
|
||||
*
|
||||
* Note:
|
||||
* if val is not 0, then it would be returned from setjmp,
|
||||
* otherwise - 0 would be returned.
|
||||
*
|
||||
* See also:
|
||||
* setjmp
|
||||
*/
|
||||
func longjmp
|
||||
ldmia r0!, {r4 - r11, lr}
|
||||
ldr sp, [r0]
|
||||
add r0, r0, #4
|
||||
vldm r0, {s16 - s31}
|
||||
mov r0, r1
|
||||
cmp r0, #0
|
||||
bne 1f
|
||||
mov r0, #1
|
||||
1:
|
||||
bx lr
|
||||
endfunc longjmp
|
||||
@@ -0,0 +1,25 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#ifndef SETJMP_H
|
||||
#define SETJMP_H
|
||||
|
||||
#include <stdint.h>
|
||||
|
||||
typedef uint64_t jmp_buf[14];
|
||||
|
||||
int setjmp (jmp_buf env);
|
||||
void longjmp (jmp_buf env, int val);
|
||||
|
||||
#endif /* !SETJMP_H */
|
||||
@@ -0,0 +1,96 @@
|
||||
# JerryScript for OpenWrt build guide
|
||||
|
||||
This document describes the steps required to compile the JerryScript
|
||||
for OpenWrt. For target device the TP-Link WR1043ND v1.x router is
|
||||
used. Please be advised, that if you have a different one minor
|
||||
modifications to this document could be required.
|
||||
|
||||
IMPORTANT!
|
||||
|
||||
As the TP-Link WR1043ND is a mips based device and mips is a big-endian
|
||||
architecture a JerryScript snapshot which was built on an little-endian
|
||||
system will not work correctly. Thus it is advised that the
|
||||
snapshot functionally should be used with caution, that is
|
||||
DO NOT run snapshots generated on little-endian system(s) on
|
||||
a big-endian system.
|
||||
|
||||
## OpenWrt notes
|
||||
|
||||
In 2018 ~January the OpenWrt and LEDE project merged into one
|
||||
and thus the old OpenWrt parts are now usable only from
|
||||
an archived repository: https://github.com/openwrt/archive
|
||||
|
||||
## OpenWrt toolchain setup
|
||||
|
||||
To build the JerryScript for OpenWrt a toolchain is required for
|
||||
the target router/device. The toolchain setup in this document was
|
||||
tested on an Ubuntu 16.04.3 LTS Linux.
|
||||
|
||||
Steps required for toolchain creation:
|
||||
|
||||
### 0. Install OpenWrt build requirements
|
||||
```sh
|
||||
$ sudo apt-get install git-core build-essential libssl-dev libncurses5-dev unzip gawk zlib1g-dev subversion mercurial
|
||||
```
|
||||
|
||||
### 1. Clone OpenWrt (Chaos Calmer version)
|
||||
|
||||
```sh
|
||||
$ git clone https://github.com/openwrt/archive openwrt -b chaos_calmer
|
||||
$ cd openwrt
|
||||
```
|
||||
|
||||
### 2. Run Menuconfig and configure the OpenWrt
|
||||
|
||||
```sh
|
||||
$ make menuconfig
|
||||
```
|
||||
|
||||
Options which should be set:
|
||||
* Set "Target System" to "Atheros AR7xxx/AR9xxx".
|
||||
* Set "Target Profile" to "TP-LINK TL-WR1043N/ND".
|
||||
|
||||
Save the configuration (as .config) and exit from the menuconfig.
|
||||
|
||||
### 3. Configure the environment variables
|
||||
|
||||
```sh
|
||||
$ export BUILDROOT=$(pwd) # where the openwrt root dir is
|
||||
$ export STAGING_DIR=${BUILDROOT}/staging_dir/ # required by the compiler
|
||||
$ export PATH=$PATH:${STAGING_DIR}/host/bin:${STAGING_DIR}/toolchain-mips_34kc_gcc-4.8-linaro_uClibc-0.9.33.2/bin/
|
||||
```
|
||||
|
||||
The name `toolchain-mips_34kc_gcc-4.8-linaro_uClibc-0.9.33.2` is created based on the menuconfig.
|
||||
This changes depending on the target device!
|
||||
|
||||
### 4. Build the OpenWrt
|
||||
|
||||
```sh
|
||||
$ make
|
||||
```
|
||||
|
||||
### 5. Check if the compiler was built
|
||||
|
||||
```sh
|
||||
$ mips-openwrt-linux-gcc --version # running this should print out the version information
|
||||
```
|
||||
|
||||
At this point we have the required compiler for OpenWrt.
|
||||
|
||||
## Build JerryScript for OpenWrt
|
||||
|
||||
### 0. Check environment
|
||||
|
||||
Please check if the `STAGING_DIR` is configured correctly and that the toolchain binary is on the `PATH`.
|
||||
|
||||
### 1. Run the build with the OpenWrt toolchain file
|
||||
|
||||
```
|
||||
$ ./tools/build.py --toolchain cmake/toolchain_openwrt_mips.cmake \
|
||||
--lto OFF
|
||||
```
|
||||
|
||||
### 2. Copy the binary
|
||||
|
||||
After a successful build the `build/bin/jerry` binary file can be copied to the target device.
|
||||
On how to copy a binary file to an OpenWrt target device please see the OpenWrt manual(s).
|
||||
@@ -0,0 +1,79 @@
|
||||
# Copyright JS Foundation and other contributors, http://js.foundation
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
|
||||
# application name
|
||||
APPLICATION = riot_jerryscript
|
||||
|
||||
# default BOARD enviroment
|
||||
BOARD ?= stm32f4discovery
|
||||
|
||||
# path to jerryscript/targets/os/riot
|
||||
TARGET_DIR = $(shell dirname $(realpath $(firstword $(MAKEFILE_LIST))))
|
||||
|
||||
# path to the JERRYSCRIPT directory
|
||||
JERRYDIR ?= $(TARGET_DIR)/../../..
|
||||
|
||||
# path to the RIOT base directory
|
||||
RIOTBASE ?= $(JERRYDIR)/../RIOT
|
||||
|
||||
# path to the application directory
|
||||
APPDIR ?= $(JERRYDIR)/targets/os/riot/source
|
||||
|
||||
# path to the binary directory
|
||||
BUILDDIR ?= $(JERRYDIR)/build/riot-stm32f4
|
||||
|
||||
# path to the binary directory
|
||||
BINDIR ?= $(BUILDDIR)/bin
|
||||
|
||||
# Change this to 0 show compiler invocation lines by default:
|
||||
QUIET ?= 1
|
||||
|
||||
INCLUDES += -I$(JERRYDIR)/jerry-core/include
|
||||
INCLUDES += -I$(JERRYDIR)/jerry-ext/include
|
||||
|
||||
ARCHIVES += $(JERRYDIR)/build/lib/libjerry-core.a
|
||||
ARCHIVES += $(JERRYDIR)/build/lib/libjerry-ext.a
|
||||
ARCHIVES += $(JERRYDIR)/build/lib/libjerry-port-default.a
|
||||
|
||||
USEMODULE += shell
|
||||
USEMODULE += shell_commands
|
||||
USEMODULE += posix_sleep
|
||||
|
||||
.PHONY: libjerry
|
||||
libjerry:
|
||||
$(JERRYDIR)/tools/build.py \
|
||||
--clean \
|
||||
--lto=OFF \
|
||||
--jerry-cmdline=OFF \
|
||||
--jerry-math=ON \
|
||||
--amalgam=ON \
|
||||
--mem-heap=70 \
|
||||
--profile=es.next \
|
||||
--compile-flag=-fshort-enums \
|
||||
--toolchain=$(abspath $(JERRYDIR)/cmake/toolchain_mcu_stm32f4.cmake)
|
||||
|
||||
.PHONY: clear-cflags
|
||||
clear-cflags:
|
||||
$(eval BACKUP := $(CFLAGS))
|
||||
$(eval CFLAGS := )
|
||||
|
||||
.PHONY: restore-cflags
|
||||
restore-cflags:
|
||||
$(eval CFLAGS := $(BACKUP))
|
||||
|
||||
# CFLAGS is filled by Makefile.include that is only for RIOT.
|
||||
# Clear CFLAGS temporarily while compiling JerryScript.
|
||||
all: clear-cflags libjerry restore-cflags
|
||||
|
||||
include $(RIOTBASE)/Makefile.include
|
||||
@@ -0,0 +1,40 @@
|
||||
# Copyright JS Foundation and other contributors, http://js.foundation
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
|
||||
|
||||
# Default target for running the build test outside the Travis CI environment.
|
||||
all:
|
||||
$(MAKE) install
|
||||
$(MAKE) script
|
||||
|
||||
|
||||
## Targets for installing build dependencies of the RIOT JerryScript target.
|
||||
|
||||
# Install cross-compiler via apt.
|
||||
install-apt-get-deps:
|
||||
sudo apt-get install -q -y clang gcc-arm-embedded gcc-multilib
|
||||
|
||||
# Fetch RIOT OS repository.
|
||||
install-clone-riot:
|
||||
git clone git://github.com/RIOT-OS/RIOT.git ../RIOT -b 2021.10
|
||||
|
||||
# Perform all the necessary (JerryScript-independent) installation steps.
|
||||
install-noapt: install-clone-riot
|
||||
install: install-apt-get-deps install-noapt
|
||||
|
||||
## Targets for building RIOT with JerryScript.
|
||||
|
||||
# Build the firmware (RIOT with JerryScript).
|
||||
script:
|
||||
$(MAKE) -f ./targets/os/riot/Makefile
|
||||
@@ -0,0 +1,117 @@
|
||||
### About
|
||||
|
||||
This folder contains files to run JerryScript on
|
||||
[STM32F4-Discovery board](https://www.st.com/en/evaluation-tools/stm32f4discovery.html) with
|
||||
[RIOT](https://www.riot-os.org/).
|
||||
The document had been validated on Ubuntu 20.04 operating system.
|
||||
|
||||
### How to build
|
||||
|
||||
#### 1. Setup the build environment for STM32F4-Discovery board
|
||||
|
||||
Clone the necessary projects into a `jerry-riot` directory.
|
||||
The latest tested working version of RIOT is `2021.10`.
|
||||
|
||||
```sh
|
||||
# Create a base folder for all the projects.
|
||||
mkdir jerry-riot && cd jerry-riot
|
||||
|
||||
git clone https://github.com/jerryscript-project/jerryscript.git
|
||||
git clone https://github.com/RIOT-OS/RIOT.git -b 2021.10
|
||||
```
|
||||
|
||||
#### 2. Install dependencies of the projects
|
||||
|
||||
```
|
||||
# Assuming you are in jerry-riot folder.
|
||||
jerryscript/tools/apt-get-install-deps.sh
|
||||
|
||||
sudo apt install gcc-arm-none-eabi openocd minicom
|
||||
```
|
||||
|
||||
The following directory structure has been created:
|
||||
|
||||
```
|
||||
jerry-riot
|
||||
+ jerryscript
|
||||
| + targets
|
||||
| + os
|
||||
| + riot
|
||||
+ RIOT
|
||||
```
|
||||
|
||||
#### 3. Build RIOT (with JerryScript)
|
||||
|
||||
```
|
||||
# Assuming you are in jerry-riot folder.
|
||||
make BOARD=stm32f4discovery -f jerryscript/targets/os/riot/Makefile
|
||||
```
|
||||
|
||||
The created binary is a `riot_jerryscript.elf` named file located in `jerryscript/build/riot-stm32f4/bin/` folder.
|
||||
|
||||
#### 4. Flash the device
|
||||
|
||||
Connect Mini-USB for charging and flashing the device.
|
||||
|
||||
```
|
||||
# Assuming you are in jerry-riot folder.
|
||||
make BOARD=stm32f4discovery -f jerryscript/targets/os/riot/Makefile flash
|
||||
```
|
||||
|
||||
Note: `ST-LINK` also can be used that is described at [this page](https://github.com/RIOT-OS/RIOT/wiki/ST-LINK-tool).
|
||||
|
||||
#### 5. Connect to the device
|
||||
|
||||
Use `USB To TTL Serial Converter` for serial communication. STM32F4-Discovery pins are mapped by RIOT as follows:
|
||||
|
||||
```
|
||||
STM32f4-Discovery PA2 pin is configured for TX.
|
||||
STM32f4-Discovery PA3 pin is configured for RX.
|
||||
```
|
||||
|
||||
* Connect `STM32f4-Discovery` **PA2** pin to **RX** pin of `USB To TTL Serial Converter`
|
||||
* Connect `STM32f4-Discovery` **PA3** pin to **TX** pin of `USB To TTL Serial Converter`
|
||||
* Connect `STM32f4-Discovery` **GND** pin to **GND** pin of `USB To TTL Serial Converter`
|
||||
|
||||
The device should be visible as `/dev/ttyUSB0`. Use `minicom` communication program with `115200`.
|
||||
|
||||
* In `minicom`, set `Add Carriage Ret` to `off` in by `CTRL-A -> Z -> U` key combinations.
|
||||
* In `minicom`, set `Hardware Flow Control` to `no` by `CTRL-A -> Z -> O -> Serial port setup -> F` key combinations.
|
||||
|
||||
```sh
|
||||
sudo minicom --device=/dev/ttyUSB0 --baud=115200
|
||||
```
|
||||
|
||||
RIOT prompt looks like as follows:
|
||||
|
||||
```
|
||||
main(): This is RIOT! (Version: 2021.10)
|
||||
You are running RIOT on a(n) stm32f4discovery board.
|
||||
This board features a(n) stm32 MCU.
|
||||
>
|
||||
```
|
||||
|
||||
You may have to press `RESET` on the board and press `Enter` key on the console several times to make RIOT prompt visible.
|
||||
|
||||
#### 6. Run JerrySript
|
||||
|
||||
Type `help` to list shell commands:
|
||||
|
||||
```
|
||||
> help
|
||||
Command Description
|
||||
---------------------------------------
|
||||
test Jerryscript Hello World test
|
||||
reboot Reboot the node
|
||||
version Prints current RIOT_VERSION
|
||||
pm interact with layered PM subsystem
|
||||
```
|
||||
|
||||
Type `test` to execute JerryScript:
|
||||
|
||||
```
|
||||
> test
|
||||
This test run the following script code: [print ('Hello, World!');]
|
||||
|
||||
Hello, World!
|
||||
```
|
||||
@@ -0,0 +1,117 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
|
||||
#include "jerryscript-port.h"
|
||||
#include "jerryscript.h"
|
||||
|
||||
#include "jerryscript-ext/handler.h"
|
||||
#include "shell.h"
|
||||
|
||||
/**
|
||||
* Standalone Jerry exit codes
|
||||
*/
|
||||
#define JERRY_STANDALONE_EXIT_CODE_OK (0)
|
||||
#define JERRY_STANDALONE_EXIT_CODE_FAIL (1)
|
||||
|
||||
/**
|
||||
* Register a JavaScript function in the global object.
|
||||
*/
|
||||
static void
|
||||
register_js_function (const char *name_p, /**< name of the function */
|
||||
jerry_external_handler_t handler_p) /**< function callback */
|
||||
{
|
||||
jerry_value_t result_val = jerryx_handler_register_global (name_p, handler_p);
|
||||
|
||||
if (jerry_value_is_exception (result_val))
|
||||
{
|
||||
printf ("Warning: failed to register '%s' method.", name_p);
|
||||
}
|
||||
|
||||
jerry_value_free (result_val);
|
||||
} /* register_js_function */
|
||||
|
||||
/**
|
||||
* Jerryscript simple test
|
||||
*/
|
||||
int
|
||||
test_jerry (int argc, char **argv)
|
||||
{
|
||||
/* Suppress compiler errors */
|
||||
(void) argc;
|
||||
(void) argv;
|
||||
|
||||
jerry_value_t ret_value = jerry_undefined ();
|
||||
|
||||
const jerry_char_t script[] = "print ('Hello, World!');";
|
||||
printf ("This test run the following script code: [%s]\n\n", script);
|
||||
|
||||
/* Initialize engine */
|
||||
jerry_init (JERRY_INIT_EMPTY);
|
||||
|
||||
/* Register the print function in the global object. */
|
||||
register_js_function ("print", jerryx_handler_print);
|
||||
|
||||
/* Setup Global scope code */
|
||||
ret_value = jerry_parse (script, sizeof (script) - 1, NULL);
|
||||
|
||||
if (!jerry_value_is_exception (ret_value))
|
||||
{
|
||||
/* Execute the parsed source code in the Global scope */
|
||||
ret_value = jerry_run (ret_value);
|
||||
}
|
||||
|
||||
int ret_code = JERRY_STANDALONE_EXIT_CODE_OK;
|
||||
|
||||
if (jerry_value_is_exception (ret_value))
|
||||
{
|
||||
printf ("Script Error!");
|
||||
|
||||
ret_code = JERRY_STANDALONE_EXIT_CODE_FAIL;
|
||||
}
|
||||
|
||||
jerry_value_free (ret_value);
|
||||
|
||||
/* Cleanup engine */
|
||||
jerry_cleanup ();
|
||||
|
||||
return ret_code;
|
||||
|
||||
} /* test_jerry */
|
||||
|
||||
const shell_command_t shell_commands[] = { { "test", "Jerryscript Hello World test", test_jerry },
|
||||
{ NULL, NULL, NULL } };
|
||||
|
||||
int
|
||||
main (void)
|
||||
{
|
||||
union
|
||||
{
|
||||
double d;
|
||||
unsigned u;
|
||||
} now = { .d = jerry_port_get_current_time () };
|
||||
srand (now.u);
|
||||
printf ("You are running RIOT on a(n) %s board.\n", RIOT_BOARD);
|
||||
printf ("This board features a(n) %s MCU.\n", RIOT_MCU);
|
||||
|
||||
/* start the shell */
|
||||
char line_buf[SHELL_DEFAULT_BUFSIZE];
|
||||
shell_run (shell_commands, line_buf, SHELL_DEFAULT_BUFSIZE);
|
||||
|
||||
return 0;
|
||||
}
|
||||
@@ -0,0 +1,45 @@
|
||||
# Copyright JS Foundation and other contributors, http://js.foundation
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
|
||||
cmake_minimum_required(VERSION 3.20.0)
|
||||
|
||||
find_package(Zephyr REQUIRED HINTS $ENV{ZEPHYR_BASE})
|
||||
project(NONE)
|
||||
|
||||
set(JERRY_BASE ${CMAKE_SOURCE_DIR}/../../..)
|
||||
|
||||
# Build JerryScript
|
||||
execute_process(COMMAND ${JERRY_BASE}/tools/build.py
|
||||
--clean
|
||||
--lto=OFF
|
||||
--jerry-cmdline=OFF
|
||||
--jerry-math=ON
|
||||
--amalgam=ON
|
||||
--mem-heap=70
|
||||
--profile=es.next
|
||||
--compile-flag=--sysroot=${ZEPHYR_BASE}
|
||||
--toolchain=${JERRY_BASE}/cmake/toolchain_mcu_stm32f4.cmake)
|
||||
|
||||
# Define library targets
|
||||
add_library(jerry-core STATIC IMPORTED)
|
||||
add_library(jerry-ext STATIC IMPORTED)
|
||||
|
||||
# Define include directories and archives
|
||||
set_target_properties(jerry-core PROPERTIES IMPORTED_LOCATION ${JERRY_BASE}/build/lib/libjerry-core.a)
|
||||
set_target_properties(jerry-core PROPERTIES INTERFACE_INCLUDE_DIRECTORIES ${JERRY_BASE}/jerry-core/include)
|
||||
set_target_properties(jerry-ext PROPERTIES IMPORTED_LOCATION ${JERRY_BASE}/build/lib/libjerry-ext.a)
|
||||
set_target_properties(jerry-ext PROPERTIES INTERFACE_INCLUDE_DIRECTORIES ${JERRY_BASE}/jerry-ext/include)
|
||||
|
||||
target_sources(app PRIVATE src/main-zephyr.c src/getline-zephyr.c src/jerry-port.c src/jerry-module.c)
|
||||
target_link_libraries(app PUBLIC jerry-core jerry-ext)
|
||||
@@ -0,0 +1,63 @@
|
||||
# Copyright JS Foundation and other contributors, http://js.foundation
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
|
||||
|
||||
# Default target for running the build test outside the Travis CI environment.
|
||||
all:
|
||||
$(MAKE) install
|
||||
$(MAKE) script
|
||||
|
||||
|
||||
## Targets for installing build dependencies of the Zephyr JerryScript target.
|
||||
|
||||
# Install tools via apt.
|
||||
install-apt-get-deps:
|
||||
sudo apt-get install -q -y gperf dfu-util device-tree-compiler gcc-arm-none-eabi
|
||||
|
||||
# Install Zephyr SDK.
|
||||
install-zephyr-toolchain:
|
||||
wget https://github.com/zephyrproject-rtos/sdk-ng/releases/download/v0.13.2/zephyr-toolchain-arm-0.13.2-linux-x86_64-setup.run -O ../zephyr-toolchain-arm-0.13.2-linux-x86_64-setup.run
|
||||
sh ../zephyr-toolchain-arm-0.13.2-linux-x86_64-setup.run -- -y -d $(CURDIR)/../zephyr-toolchain-0.13.2
|
||||
|
||||
# Fetch Zephyr Project repository and install python dependencies.
|
||||
install-zephyr:
|
||||
git clone https://github.com/zephyrproject-rtos/zephyr.git ../zephyr -b v2.7.0
|
||||
pip3 install -U pip
|
||||
pip3 install -U setuptools
|
||||
pip3 install -r ../zephyr/scripts/requirements.txt
|
||||
|
||||
# Install recent CMake
|
||||
install-cmake:
|
||||
pip install cmake
|
||||
cmake --version
|
||||
|
||||
# Perform all the necessary (JerryScript-independent) installation steps.
|
||||
install-noapt: install-zephyr-toolchain install-zephyr install-cmake
|
||||
install: install-apt-get-deps install-noapt
|
||||
|
||||
|
||||
## Targets for building Zephyr with JerryScript.
|
||||
|
||||
# Initialize west meta-tool
|
||||
init-west:
|
||||
west init -l $(CURDIR)/../zephyr
|
||||
west update hal_stm32 cmsis
|
||||
west zephyr-export
|
||||
|
||||
# Build the firmware (Zephyr with JerryScript).
|
||||
SHELL=bash
|
||||
script: init-west
|
||||
export ZEPHYR_TOOLCHAIN_VARIANT=zephyr && \
|
||||
export ZEPHYR_SDK_INSTALL_DIR=$(CURDIR)/../zephyr-toolchain-0.13.2 && \
|
||||
west build -d $(CURDIR)/../build -p auto -b stm32f4_disco targets/os/zephyr/ -- -G'Unix Makefiles'
|
||||
@@ -0,0 +1,130 @@
|
||||
### About
|
||||
|
||||
This folder contains files to run JerryScript on
|
||||
[STM32F4-Discovery board](https://www.st.com/en/evaluation-tools/stm32f4discovery.html) with
|
||||
[Zephyr](https://zephyrproject.org/).
|
||||
The document had been validated on Ubuntu 20.04 operating system.
|
||||
|
||||
#### 1. Setup the build environment
|
||||
|
||||
Clone the necessary projects into a `jerry-zephyr` directory.
|
||||
The latest tested working version of Zephyr is `v2.7.0`.
|
||||
|
||||
```sh
|
||||
mkdir jerry-zephyr && cd jerry-zephyr
|
||||
|
||||
git clone https://github.com/jerryscript-project/jerryscript.git
|
||||
git clone https://github.com/zephyrproject-rtos/zephyr -b v2.7.0
|
||||
|
||||
# Zephyr requires its toolchain.
|
||||
wget https://github.com/zephyrproject-rtos/sdk-ng/releases/download/v0.13.2/zephyr-toolchain-arm-0.13.2-linux-x86_64-setup.run
|
||||
```
|
||||
|
||||
The following directory structure has been created:
|
||||
|
||||
```
|
||||
jerry-zephyr
|
||||
+ jerryscript
|
||||
| + targets
|
||||
| + os
|
||||
| + zephyr
|
||||
+ zephyr
|
||||
+ zephyr-toolchain-arm-0.13.2-linux-x86_64-setup.run
|
||||
```
|
||||
|
||||
#### 2. Install dependencies of the projects
|
||||
|
||||
```sh
|
||||
# Assuming you are in jerry-zephyr folder.
|
||||
jerryscript/tools/apt-get-install-deps.sh
|
||||
|
||||
# Tool dependencies of Zephyr.
|
||||
sudo apt install --no-install-recommends \
|
||||
git cmake ninja-build gperf ccache dfu-util device-tree-compiler \
|
||||
python3-dev python3-pip python3-setuptools python3-tk python3-wheel \
|
||||
xz-utils file make gcc gcc-multilib g++-multilib libsdl2-dev
|
||||
|
||||
# Install Python dependencies of Zephyr.
|
||||
pip3 install --user -r zephyr/scripts/requirements.txt
|
||||
|
||||
# Install Zephyr toolchain.
|
||||
chmod +x zephyr-toolchain-arm-0.13.2-linux-x86_64-setup.run
|
||||
./zephyr-toolchain-arm-0.13.2-linux-x86_64-setup.run -- -y -d ${PWD}/zephyr-toolchain-0.13.2
|
||||
```
|
||||
|
||||
Note: CMake 3.20 is required. If the installed CMake is older, upgrade it for example [this way](https://apt.kitware.com/).
|
||||
|
||||
#### 3. Initialize west meta-tool for Zephyr
|
||||
|
||||
```
|
||||
# Assuming you are in jerry-zephyr folder.
|
||||
west init -l zephyr
|
||||
west update hal_stm32 cmsis
|
||||
west zephyr-export
|
||||
```
|
||||
|
||||
#### 4. Build Zephyr (with JerryScript)
|
||||
|
||||
```
|
||||
# Assuming you are in jerry-zephyr folder.
|
||||
west build -p auto -b stm32f4_disco jerryscript/targets/os/zephyr/
|
||||
```
|
||||
|
||||
The created binary is a `zephyr.elf` named file located in `jerry-zephyr/build/zephyr/bin/` folder.
|
||||
|
||||
#### 5. Flash
|
||||
|
||||
Install `udev` rules which allows to flash STM32F4-Discovery as a regular user:
|
||||
|
||||
```
|
||||
# Assuming you are in jerry-zephyr folder.
|
||||
sudo cp zephyr-toolchain-0.13.2/sysroots/x86_64-pokysdk-linux/usr/share/openocd/contrib/60-openocd.rules /etc/udev/rules.d
|
||||
sudo udevadm control --reload
|
||||
```
|
||||
|
||||
Connect Mini-USB for charging and flasing the device.
|
||||
|
||||
```
|
||||
# Assuming you are in jerry-zephyr folder.
|
||||
west flash
|
||||
```
|
||||
|
||||
#### 6. Connect to the device
|
||||
|
||||
Use `USB To TTL Serial Converter` for serial communication. STM32F4-Discovery pins are mapped by Zephyr as follows:
|
||||
|
||||
```
|
||||
STM32f4-Discovery PA2 pin is configured for TX.
|
||||
STM32f4-Discovery PA3 pin is configured for RX.
|
||||
```
|
||||
|
||||
* Connect `STM32f4-Discovery` **PA2** pin to **RX** pin of `USB To TTL Serial Converter`
|
||||
* Connect `STM32f4-Discovery` **PA3** pin to **TX** pin of `USB To TTL Serial Converter`
|
||||
* Connect `STM32f4-Discovery` **GND** pin to **GND** pin of `USB To TTL Serial Converter`
|
||||
|
||||
The device should be visible as `/dev/ttyUSB0`. Use `minicom` communication program with `115200`.
|
||||
|
||||
* In `minicom`, set `Add Carriage Ret` to `off` in by `CTRL-A -> Z -> U` key combinations.
|
||||
* In `minicom`, set `Hardware Flow Control` to `no` by `CTRL-A -> Z -> O -> Serial port setup -> F` key combinations.
|
||||
|
||||
```sh
|
||||
sudo minicom --device=/dev/ttyUSB0 --baud=115200
|
||||
```
|
||||
|
||||
Press `RESET` on the board to get the initial message with JerryScript command prompt:
|
||||
|
||||
```
|
||||
*** Booting Zephyr OS build v2.7.99-1786-ga08b65ef42db ***
|
||||
JerryScript build: Nov 25 2021 14:17:17
|
||||
JerryScript API 3.0.0
|
||||
Zephyr version 2.7.99
|
||||
js>
|
||||
```
|
||||
|
||||
Run the following JavaScript example:
|
||||
|
||||
```
|
||||
js> var test = 0; for (t = 100; t < 1000; t++) test += t; print ('Hello World! ' + test);
|
||||
Hello World! 494550
|
||||
undefined
|
||||
```
|
||||
@@ -0,0 +1,6 @@
|
||||
CONFIG_BUILD_OUTPUT_BIN=y
|
||||
CONFIG_STDOUT_CONSOLE=y
|
||||
CONFIG_NEWLIB_LIBC=y
|
||||
CONFIG_FPU=y
|
||||
CONFIG_MAIN_STACK_SIZE=2048
|
||||
CONFIG_CONSOLE_HANDLER=y
|
||||
@@ -0,0 +1,58 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include <zephyr.h>
|
||||
#include <drivers/uart.h>
|
||||
#include <drivers/console/console.h>
|
||||
#include <drivers/console/uart_console.h>
|
||||
#include "getline-zephyr.h"
|
||||
|
||||
/* While app processes one input line, Zephyr will have another line
|
||||
buffer to accumulate more console input. */
|
||||
static struct console_input line_bufs[2];
|
||||
|
||||
static struct k_fifo free_queue;
|
||||
static struct k_fifo used_queue;
|
||||
|
||||
char *zephyr_getline(void)
|
||||
{
|
||||
static struct console_input *cmd;
|
||||
|
||||
/* Recycle cmd buffer returned previous time */
|
||||
if (cmd != NULL)
|
||||
{
|
||||
k_fifo_put(&free_queue, cmd);
|
||||
}
|
||||
|
||||
cmd = k_fifo_get(&used_queue, K_FOREVER);
|
||||
return cmd->line;
|
||||
}
|
||||
|
||||
void zephyr_getline_init(void)
|
||||
{
|
||||
int i;
|
||||
|
||||
k_fifo_init(&used_queue);
|
||||
k_fifo_init(&free_queue);
|
||||
for (i = 0; i < sizeof(line_bufs) / sizeof(*line_bufs); i++)
|
||||
{
|
||||
k_fifo_put(&free_queue, &line_bufs[i]);
|
||||
}
|
||||
|
||||
/* Zephyr UART handler takes an empty buffer from free_queue,
|
||||
stores UART input in it until EOL, and then puts it into
|
||||
used_queue. */
|
||||
uart_register_input(&free_queue, &used_queue, NULL);
|
||||
}
|
||||
@@ -0,0 +1,17 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
void zephyr_getline_init(void);
|
||||
char *zephyr_getline(void);
|
||||
@@ -0,0 +1,293 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#include "jerryscript-port.h"
|
||||
#include "jerryscript.h"
|
||||
|
||||
/**
|
||||
* Computes the end of the directory part of a path.
|
||||
*
|
||||
* @return end of the directory part of a path.
|
||||
*/
|
||||
static size_t
|
||||
jerry_port_get_directory_end (const jerry_char_t *path_p) /**< path */
|
||||
{
|
||||
const jerry_char_t *end_p = path_p + strlen ((const char *) path_p);
|
||||
|
||||
while (end_p > path_p)
|
||||
{
|
||||
if (end_p[-1] == '/')
|
||||
{
|
||||
return (size_t) (end_p - path_p);
|
||||
}
|
||||
|
||||
end_p--;
|
||||
}
|
||||
|
||||
return 0;
|
||||
} /* jerry_port_get_directory_end */
|
||||
|
||||
/**
|
||||
* Normalize a file path.
|
||||
*
|
||||
* @return a newly allocated buffer with the normalized path if the operation is successful,
|
||||
* NULL otherwise
|
||||
*/
|
||||
static jerry_char_t *
|
||||
jerry_port_normalize_path (const jerry_char_t *in_path_p, /**< path to the referenced module */
|
||||
size_t in_path_length, /**< length of the path */
|
||||
const jerry_char_t *base_path_p, /**< base path */
|
||||
size_t base_path_length) /**< length of the base path */
|
||||
{
|
||||
char *path_p;
|
||||
|
||||
if (base_path_length > 0)
|
||||
{
|
||||
path_p = (char *) malloc (base_path_length + in_path_length + 1);
|
||||
|
||||
if (path_p == NULL)
|
||||
{
|
||||
return NULL;
|
||||
}
|
||||
|
||||
memcpy (path_p, base_path_p, base_path_length);
|
||||
memcpy (path_p + base_path_length, in_path_p, in_path_length);
|
||||
path_p[base_path_length + in_path_length] = '\0';
|
||||
}
|
||||
else
|
||||
{
|
||||
path_p = (char *) malloc (in_path_length + 1);
|
||||
|
||||
if (path_p == NULL)
|
||||
{
|
||||
return NULL;
|
||||
}
|
||||
|
||||
memcpy (path_p, in_path_p, in_path_length);
|
||||
path_p[in_path_length] = '\0';
|
||||
}
|
||||
|
||||
return (jerry_char_t *) path_p;
|
||||
} /* jerry_port_normalize_path */
|
||||
|
||||
/**
|
||||
* A module descriptor.
|
||||
*/
|
||||
typedef struct jerry_port_module_t
|
||||
{
|
||||
struct jerry_port_module_t *next_p; /**< next_module */
|
||||
jerry_char_t *path_p; /**< path to the module */
|
||||
size_t base_path_length; /**< base path length for relative difference */
|
||||
jerry_value_t realm; /**< the realm of the module */
|
||||
jerry_value_t module; /**< the module itself */
|
||||
} jerry_port_module_t;
|
||||
|
||||
/**
|
||||
* Native info descriptor for modules.
|
||||
*/
|
||||
static const jerry_object_native_info_t jerry_port_module_native_info = {
|
||||
.free_cb = NULL,
|
||||
};
|
||||
|
||||
/**
|
||||
* Default module manager.
|
||||
*/
|
||||
typedef struct
|
||||
{
|
||||
jerry_port_module_t *module_head_p; /**< first module */
|
||||
} jerry_port_module_manager_t;
|
||||
|
||||
/**
|
||||
* Release known modules.
|
||||
*/
|
||||
static void
|
||||
jerry_port_module_free (jerry_port_module_manager_t *manager_p, /**< module manager */
|
||||
const jerry_value_t realm) /**< if this argument is object, release only those modules,
|
||||
* which realm value is equal to this argument. */
|
||||
{
|
||||
jerry_port_module_t *module_p = manager_p->module_head_p;
|
||||
|
||||
bool release_all = !jerry_value_is_object (realm);
|
||||
|
||||
jerry_port_module_t *prev_p = NULL;
|
||||
|
||||
while (module_p != NULL)
|
||||
{
|
||||
jerry_port_module_t *next_p = module_p->next_p;
|
||||
|
||||
if (release_all || module_p->realm == realm)
|
||||
{
|
||||
free (module_p->path_p);
|
||||
jerry_value_free (module_p->realm);
|
||||
jerry_value_free (module_p->module);
|
||||
|
||||
free (module_p);
|
||||
|
||||
if (prev_p == NULL)
|
||||
{
|
||||
manager_p->module_head_p = next_p;
|
||||
}
|
||||
else
|
||||
{
|
||||
prev_p->next_p = next_p;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
prev_p = module_p;
|
||||
}
|
||||
|
||||
module_p = next_p;
|
||||
}
|
||||
} /* jerry_port_module_free */
|
||||
|
||||
/**
|
||||
* Initialize the default module manager.
|
||||
*/
|
||||
static void
|
||||
jerry_port_module_manager_init (void *user_data_p)
|
||||
{
|
||||
((jerry_port_module_manager_t *) user_data_p)->module_head_p = NULL;
|
||||
} /* jerry_port_module_manager_init */
|
||||
|
||||
/**
|
||||
* Deinitialize the default module manager.
|
||||
*/
|
||||
static void
|
||||
jerry_port_module_manager_deinit (void *user_data_p) /**< context pointer to deinitialize */
|
||||
{
|
||||
jerry_value_t undef = jerry_undefined ();
|
||||
jerry_port_module_free ((jerry_port_module_manager_t *) user_data_p, undef);
|
||||
jerry_value_free (undef);
|
||||
} /* jerry_port_module_manager_deinit */
|
||||
|
||||
/**
|
||||
* Declare the context data manager for modules.
|
||||
*/
|
||||
static const jerry_context_data_manager_t jerry_port_module_manager = { .init_cb = jerry_port_module_manager_init,
|
||||
.deinit_cb = jerry_port_module_manager_deinit,
|
||||
.bytes_needed =
|
||||
sizeof (jerry_port_module_manager_t) };
|
||||
|
||||
/**
|
||||
* Default module resolver.
|
||||
*
|
||||
* @return a module object if resolving is successful, an error otherwise
|
||||
*/
|
||||
jerry_value_t
|
||||
jerry_port_module_resolve (const jerry_value_t specifier, /**< module specifier string */
|
||||
const jerry_value_t referrer, /**< parent module */
|
||||
void *user_p) /**< user data */
|
||||
{
|
||||
(void) user_p;
|
||||
|
||||
jerry_port_module_t *module_p = jerry_object_get_native_ptr (referrer, &jerry_port_module_native_info);
|
||||
const jerry_char_t *base_path_p = NULL;
|
||||
size_t base_path_length = 0;
|
||||
|
||||
if (module_p != NULL)
|
||||
{
|
||||
base_path_p = module_p->path_p;
|
||||
base_path_length = module_p->base_path_length;
|
||||
}
|
||||
|
||||
jerry_size_t in_path_length = jerry_string_size (specifier, JERRY_ENCODING_UTF8);
|
||||
jerry_char_t *in_path_p = (jerry_char_t *) malloc (in_path_length + 1);
|
||||
jerry_string_to_buffer (specifier, JERRY_ENCODING_UTF8, in_path_p, in_path_length);
|
||||
in_path_p[in_path_length] = '\0';
|
||||
|
||||
jerry_char_t *path_p = jerry_port_normalize_path (in_path_p, in_path_length, base_path_p, base_path_length);
|
||||
|
||||
if (path_p == NULL)
|
||||
{
|
||||
return jerry_throw_sz (JERRY_ERROR_COMMON, "Out of memory");
|
||||
}
|
||||
|
||||
jerry_value_t realm = jerry_current_realm ();
|
||||
|
||||
jerry_port_module_manager_t *manager_p;
|
||||
manager_p = (jerry_port_module_manager_t *) jerry_context_data (&jerry_port_module_manager);
|
||||
|
||||
module_p = manager_p->module_head_p;
|
||||
|
||||
while (module_p != NULL)
|
||||
{
|
||||
if (module_p->realm == realm && strcmp ((const char *) module_p->path_p, (const char *) path_p) == 0)
|
||||
{
|
||||
free (path_p);
|
||||
free (in_path_p);
|
||||
jerry_value_free (realm);
|
||||
return jerry_value_copy (module_p->module);
|
||||
}
|
||||
|
||||
module_p = module_p->next_p;
|
||||
}
|
||||
|
||||
size_t source_size;
|
||||
uint8_t *source_p = jerry_port_read_source ((const char *) path_p, &source_size);
|
||||
|
||||
if (source_p == NULL)
|
||||
{
|
||||
free (path_p);
|
||||
free (in_path_p);
|
||||
jerry_value_free (realm);
|
||||
return jerry_throw_sz (JERRY_ERROR_SYNTAX, "Module file not found");
|
||||
}
|
||||
|
||||
jerry_parse_options_t parse_options;
|
||||
parse_options.options = JERRY_PARSE_MODULE | JERRY_PARSE_HAS_SOURCE_NAME;
|
||||
parse_options.source_name = jerry_string ((const jerry_char_t *) in_path_p, in_path_length, JERRY_ENCODING_UTF8);
|
||||
|
||||
jerry_value_t ret_value = jerry_parse (source_p, source_size, &parse_options);
|
||||
|
||||
jerry_value_free (parse_options.source_name);
|
||||
jerry_port_release_source (source_p);
|
||||
free (in_path_p);
|
||||
|
||||
if (jerry_value_is_exception (ret_value))
|
||||
{
|
||||
free (path_p);
|
||||
jerry_value_free (realm);
|
||||
return ret_value;
|
||||
}
|
||||
|
||||
module_p = (jerry_port_module_t *) malloc (sizeof (jerry_port_module_t));
|
||||
|
||||
module_p->next_p = manager_p->module_head_p;
|
||||
module_p->path_p = path_p;
|
||||
module_p->base_path_length = jerry_port_get_directory_end (module_p->path_p);
|
||||
module_p->realm = realm;
|
||||
module_p->module = jerry_value_copy (ret_value);
|
||||
|
||||
jerry_object_set_native_ptr (ret_value, &jerry_port_module_native_info, module_p);
|
||||
manager_p->module_head_p = module_p;
|
||||
|
||||
return ret_value;
|
||||
} /* jerry_port_module_resolve */
|
||||
|
||||
/**
|
||||
* Release known modules.
|
||||
*/
|
||||
void
|
||||
jerry_port_module_release (const jerry_value_t realm) /**< if this argument is object, release only those modules,
|
||||
* which realm value is equal to this argument. */
|
||||
{
|
||||
jerry_port_module_free ((jerry_port_module_manager_t *) jerry_context_data (&jerry_port_module_manager), realm);
|
||||
} /* jerry_port_module_release */
|
||||
@@ -0,0 +1,192 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include <zephyr.h>
|
||||
#include <stdarg.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
#include "jerryscript-port.h"
|
||||
|
||||
/**
|
||||
* JerryScript log level
|
||||
*/
|
||||
static jerry_log_level_t jerry_log_level = JERRY_LOG_LEVEL_ERROR;
|
||||
|
||||
/**
|
||||
* Sets log level.
|
||||
*/
|
||||
void set_log_level (jerry_log_level_t level)
|
||||
{
|
||||
jerry_log_level = level;
|
||||
} /* set_log_level */
|
||||
|
||||
/**
|
||||
* Aborts the program.
|
||||
*/
|
||||
void jerry_port_fatal (jerry_fatal_code_t code)
|
||||
{
|
||||
exit (1);
|
||||
} /* jerry_port_fatal */
|
||||
|
||||
/**
|
||||
* Provide log message implementation for the engine.
|
||||
*/
|
||||
void
|
||||
jerry_port_log (jerry_log_level_t level, /**< log level */
|
||||
const char *format, /**< format string */
|
||||
...) /**< parameters */
|
||||
{
|
||||
if (level <= jerry_log_level)
|
||||
{
|
||||
va_list args;
|
||||
va_start (args, format);
|
||||
vfprintf (stderr, format, args);
|
||||
va_end (args);
|
||||
}
|
||||
} /* jerry_port_log */
|
||||
|
||||
/**
|
||||
* Determines the size of the given file.
|
||||
* @return size of the file
|
||||
*/
|
||||
static size_t
|
||||
jerry_port_get_file_size (FILE *file_p) /**< opened file */
|
||||
{
|
||||
fseek (file_p, 0, SEEK_END);
|
||||
long size = ftell (file_p);
|
||||
fseek (file_p, 0, SEEK_SET);
|
||||
|
||||
return (size_t) size;
|
||||
} /* jerry_port_get_file_size */
|
||||
|
||||
/**
|
||||
* Opens file with the given path and reads its source.
|
||||
* @return the source of the file
|
||||
*/
|
||||
uint8_t *
|
||||
jerry_port_read_source (const char *file_name_p, /**< file name */
|
||||
size_t *out_size_p) /**< [out] read bytes */
|
||||
{
|
||||
FILE *file_p = fopen (file_name_p, "rb");
|
||||
|
||||
if (file_p == NULL)
|
||||
{
|
||||
jerry_port_log (JERRY_LOG_LEVEL_ERROR, "Error: failed to open file: %s\n", file_name_p);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
size_t file_size = jerry_port_get_file_size (file_p);
|
||||
uint8_t *buffer_p = (uint8_t *) malloc (file_size);
|
||||
|
||||
if (buffer_p == NULL)
|
||||
{
|
||||
fclose (file_p);
|
||||
|
||||
jerry_port_log (JERRY_LOG_LEVEL_ERROR, "Error: failed to allocate memory for module");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
size_t bytes_read = fread (buffer_p, 1u, file_size, file_p);
|
||||
|
||||
if (!bytes_read)
|
||||
{
|
||||
fclose (file_p);
|
||||
free (buffer_p);
|
||||
|
||||
jerry_port_log (JERRY_LOG_LEVEL_ERROR, "Error: failed to read file: %s\n", file_name_p);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
fclose (file_p);
|
||||
*out_size_p = bytes_read;
|
||||
|
||||
return buffer_p;
|
||||
} /* jerry_port_read_source */
|
||||
|
||||
/**
|
||||
* Release the previously opened file's content.
|
||||
*/
|
||||
void
|
||||
jerry_port_release_source (uint8_t *buffer_p) /**< buffer to free */
|
||||
{
|
||||
free (buffer_p);
|
||||
} /* jerry_port_release_source */
|
||||
|
||||
/**
|
||||
* Dummy function to get the time zone adjustment.
|
||||
*
|
||||
* @return 0
|
||||
*/
|
||||
double
|
||||
jerry_port_get_local_time_zone_adjustment (double unix_ms, bool is_utc)
|
||||
{
|
||||
/* We live in UTC. */
|
||||
return 0;
|
||||
} /* jerry_port_get_local_time_zone_adjustment */
|
||||
|
||||
/**
|
||||
* Dummy function to get the current time.
|
||||
*
|
||||
* @return 0
|
||||
*/
|
||||
double
|
||||
jerry_port_get_current_time (void)
|
||||
{
|
||||
int64_t ms = k_uptime_get();
|
||||
return (double) ms;
|
||||
} /* jerry_port_get_current_time */
|
||||
|
||||
/**
|
||||
* Provide the implementation of jerry_port_print_char.
|
||||
* Uses 'printf' to print a single character to standard output.
|
||||
*/
|
||||
void
|
||||
jerry_port_print_char (char c) /**< the character to print */
|
||||
{
|
||||
printf ("%c", c);
|
||||
} /* jerry_port_print_char */
|
||||
|
||||
/**
|
||||
* Provide implementation of jerry_port_sleep.
|
||||
*/
|
||||
void jerry_port_sleep (uint32_t sleep_time) /**< milliseconds to sleep */
|
||||
{
|
||||
k_usleep ((useconds_t) sleep_time * 1000);
|
||||
} /* jerry_port_sleep */
|
||||
|
||||
/**
|
||||
* Pointer to the current context.
|
||||
*/
|
||||
static jerry_context_t *current_context_p = NULL;
|
||||
|
||||
/**
|
||||
* Set the current_context_p as the passed pointer.
|
||||
*/
|
||||
void
|
||||
jerry_port_default_set_current_context (jerry_context_t *context_p) /**< points to the created context */
|
||||
{
|
||||
current_context_p = context_p;
|
||||
} /* jerry_port_default_set_current_context */
|
||||
|
||||
/**
|
||||
* Get the current context.
|
||||
*
|
||||
* @return the pointer to the current context
|
||||
*/
|
||||
jerry_context_t *
|
||||
jerry_port_get_current_context (void)
|
||||
{
|
||||
return current_context_p;
|
||||
} /* jerry_port_get_current_context */
|
||||
@@ -0,0 +1,120 @@
|
||||
/* Copyright JS Foundation and other contributors, http://js.foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <zephyr.h>
|
||||
|
||||
#include "jerryscript-port.h"
|
||||
#include "jerryscript.h"
|
||||
|
||||
#include "getline-zephyr.h"
|
||||
#include "jerryscript-ext/handler.h"
|
||||
#include <sys/printk.h>
|
||||
|
||||
static jerry_value_t print_function;
|
||||
|
||||
/**
|
||||
* Register a JavaScript function in the global object.
|
||||
*/
|
||||
static void
|
||||
register_js_function (const char *name_p, /**< name of the function */
|
||||
jerry_external_handler_t handler_p) /**< function callback */
|
||||
{
|
||||
jerry_value_t result_val = jerryx_handler_register_global (name_p, handler_p);
|
||||
|
||||
if (jerry_value_is_exception (result_val))
|
||||
{
|
||||
jerry_port_log (JERRY_LOG_LEVEL_WARNING, "Warning: failed to register '%s' method.", name_p);
|
||||
}
|
||||
|
||||
jerry_value_free (result_val);
|
||||
} /* register_js_function */
|
||||
|
||||
static int
|
||||
shell_cmd_handler (char *source_buffer)
|
||||
{
|
||||
jerry_value_t ret_val;
|
||||
|
||||
ret_val = jerry_eval ((jerry_char_t *) source_buffer, strlen (source_buffer), JERRY_PARSE_NO_OPTS);
|
||||
|
||||
if (jerry_value_is_exception (ret_val))
|
||||
{
|
||||
/* User-friendly error messages require at least "cp" JerryScript
|
||||
profile. Include a message prefix in case "cp_minimal" profile
|
||||
is used. */
|
||||
printf ("Error executing statement: ");
|
||||
/* Clear error flag, otherwise print call below won't produce any
|
||||
output. */
|
||||
ret_val = jerry_exception_value (ret_val, true);
|
||||
}
|
||||
|
||||
if (!jerry_value_is_exception (print_function))
|
||||
{
|
||||
jerry_value_t ret_val_print = jerry_call (print_function, jerry_undefined (), &ret_val, 1);
|
||||
jerry_value_free (ret_val_print);
|
||||
}
|
||||
|
||||
jerry_value_free (ret_val);
|
||||
|
||||
return 0;
|
||||
} /* shell_cmd_handler */
|
||||
|
||||
void
|
||||
main (void)
|
||||
{
|
||||
union
|
||||
{
|
||||
double d;
|
||||
unsigned u;
|
||||
} now = { .d = jerry_port_get_current_time () };
|
||||
srand (now.u);
|
||||
uint32_t zephyr_ver = sys_kernel_version_get ();
|
||||
printf ("JerryScript build: " __DATE__ " " __TIME__ "\n");
|
||||
printf ("JerryScript API %d.%d.%d\n", JERRY_API_MAJOR_VERSION, JERRY_API_MINOR_VERSION, JERRY_API_PATCH_VERSION);
|
||||
printf ("Zephyr version %d.%d.%d\n",
|
||||
(int) SYS_KERNEL_VER_MAJOR (zephyr_ver),
|
||||
(int) SYS_KERNEL_VER_MINOR (zephyr_ver),
|
||||
(int) SYS_KERNEL_VER_PATCHLEVEL (zephyr_ver));
|
||||
|
||||
zephyr_getline_init ();
|
||||
jerry_init (JERRY_INIT_EMPTY);
|
||||
register_js_function ("print", jerryx_handler_print);
|
||||
jerry_value_t global_obj_val = jerry_current_realm ();
|
||||
|
||||
jerry_value_t print_func_name_val = jerry_string_sz ("print");
|
||||
print_function = jerry_object_get (global_obj_val, print_func_name_val);
|
||||
jerry_value_free (print_func_name_val);
|
||||
jerry_value_free (global_obj_val);
|
||||
if (jerry_value_is_exception (print_function))
|
||||
{
|
||||
printf ("Error: could not look up print function, expression results won't be printed\n");
|
||||
}
|
||||
|
||||
while (1)
|
||||
{
|
||||
char *s;
|
||||
printf ("js> ");
|
||||
fflush (stdout);
|
||||
s = zephyr_getline ();
|
||||
if (*s)
|
||||
{
|
||||
shell_cmd_handler (s);
|
||||
}
|
||||
}
|
||||
|
||||
/* As we never retturn from REPL above, don't call jerry_cleanup() here. */
|
||||
} /* main */
|
||||
Reference in New Issue
Block a user