tools: Split origin Wasm.mk into Wasm.mk and WASI-SDK.defs
Try to follow current NuttX's toolchain parttern: Wasm.mk: Provide target rule for building wasm module WASI-SDK.defs: Provide compile flags for building Signed-off-by: Huang Qi <huangqi3@xiaomi.com>
This commit is contained in:
parent
f55b8face6
commit
bd159e103c
86
tools/WASI-SDK.defs
Normal file
86
tools/WASI-SDK.defs
Normal file
@ -0,0 +1,86 @@
|
|||||||
|
|
||||||
|
############################################################################
|
||||||
|
# apps/tools/WASI-SDK.defs
|
||||||
|
#
|
||||||
|
# Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
# contributor license agreements. See the NOTICE file distributed with
|
||||||
|
# this work for additional information regarding copyright ownership. The
|
||||||
|
# ASF licenses this file to you 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.
|
||||||
|
#
|
||||||
|
############################################################################
|
||||||
|
|
||||||
|
# wasi-sdk toolchain
|
||||||
|
|
||||||
|
WCC ?= $(WASI_SDK_PATH)/bin/clang
|
||||||
|
WAR ?= $(WASI_SDK_PATH)/bin/llvm-ar rcs
|
||||||
|
|
||||||
|
# Sysroot for building wasm module, default is NuttX
|
||||||
|
|
||||||
|
WSYSROOT ?= $(TOPDIR)
|
||||||
|
|
||||||
|
# Force disable wasm build when WCC is not exist
|
||||||
|
|
||||||
|
ifeq ($(wildcard $(WCC)),)
|
||||||
|
WASM_BUILD = n
|
||||||
|
else
|
||||||
|
WASM_BUILD ?= n
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Force disable wasm build when WASM_SYSROOT is not defined and on specific
|
||||||
|
# targets that do not support wasm build.
|
||||||
|
# Since some architecture level inline assembly instructions can not be
|
||||||
|
# recognized by wasm-clang. For example:
|
||||||
|
# Error: /github/workspace/sources/nuttx/include/arch/chip/irq.h:220:27: error: invalid output constraint '=a' in asm
|
||||||
|
# asm volatile("rdtscp" : "=a" (lo), "=d" (hi)::"memory");
|
||||||
|
|
||||||
|
ifeq ($(CONFIG_ARCH_INTEL64)$(CONFIG_ARCH_SPARC_V8)$(CONFIG_ARCH_AVR)$(CONFIG_ARCH_XTENSA),y)
|
||||||
|
WASM_BUILD = n
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Build optimization flags from scratch
|
||||||
|
|
||||||
|
ifeq ($(CONFIG_DEBUG_FULLOPT),y)
|
||||||
|
WCFLAGS += -Oz
|
||||||
|
else ifeq ($(CONFIG_DEBUG_CUSTOMOPT),y)
|
||||||
|
WCFLAGS += $(CONFIG_DEBUG_OPTLEVEL)
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifneq ($(CONFIG_LTO_FULL)$(CONFIG_LTO_THIN),)
|
||||||
|
WCFLAGS += -flto
|
||||||
|
WLDFLAGS += -flto
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Build other compiler flags from native compiler
|
||||||
|
|
||||||
|
CFLAGS_STRIP = -fsanitize=kernel-address -fsanitize=address -fsanitize=undefined
|
||||||
|
CFLAGS_STRIP += $(ARCHCPUFLAGS) $(ARCHCFLAGS) $(ARCHINCLUDES) $(ARCHDEFINES) $(ARCHOPTIMIZATION) $(EXTRAFLAGS)
|
||||||
|
|
||||||
|
WCFLAGS += $(filter-out $(CFLAGS_STRIP),$(CFLAGS))
|
||||||
|
WCFLAGS += --sysroot=$(WSYSROOT) -nostdlib -D__NuttX__
|
||||||
|
|
||||||
|
# If CONFIG_LIBM not defined, then define it to 1
|
||||||
|
ifeq ($(CONFIG_LIBM),)
|
||||||
|
WCFLAGS += -DCONFIG_LIBM=1 -I$(APPDIR)$(DELIM)include$(DELIM)wasm
|
||||||
|
endif
|
||||||
|
|
||||||
|
WLDFLAGS += -z stack-size=$(STACKSIZE) -Wl,--initial-memory=$(INITIAL_MEMORY)
|
||||||
|
WLDFLAGS += -Wl,--export=main -Wl,--export=__main_argc_argv
|
||||||
|
WLDFLAGS += -Wl,--export=__heap_base -Wl,--export=__data_end
|
||||||
|
WLDFLAGS += -Wl,--no-entry -Wl,--strip-all -Wl,--allow-undefined
|
||||||
|
|
||||||
|
WCC_COMPILER_RT_LIB = $(shell $(WCC) --print-libgcc-file-name)
|
||||||
|
ifeq ($(wildcard $(WCC_COMPILER_RT_LIB)),)
|
||||||
|
# if "--print-libgcc-file-name" unable to find the correct libgcc PATH
|
||||||
|
# then go ahead and try "--print-file-name"
|
||||||
|
WCC_COMPILER_RT_LIB := $(wildcard $(shell $(WCC) --print-file-name $(notdir $(WCC_COMPILER_RT_LIB))))
|
||||||
|
endif
|
@ -22,63 +22,13 @@
|
|||||||
# Only build wasm if one of the following runtime is enabled
|
# Only build wasm if one of the following runtime is enabled
|
||||||
|
|
||||||
ifneq ($(CONFIG_INTERPRETERS_WAMR)$(CONFIG_INTERPRETERS_WASM)$(CONFIG_INTERPRETERS_TOYWASM),)
|
ifneq ($(CONFIG_INTERPRETERS_WAMR)$(CONFIG_INTERPRETERS_WASM)$(CONFIG_INTERPRETERS_TOYWASM),)
|
||||||
|
include $(APPDIR)$(DELIM)tools$(DELIM)WASI-SDK.defs
|
||||||
include $(APPDIR)$(DELIM)interpreters$(DELIM)wamr$(DELIM)Toolchain.defs
|
include $(APPDIR)$(DELIM)interpreters$(DELIM)wamr$(DELIM)Toolchain.defs
|
||||||
|
|
||||||
# wasi-sdk toolchain setting
|
# If called from $(APPDIR)/Makefile,
|
||||||
|
|
||||||
WCC ?= $(WASI_SDK_PATH)/bin/clang
|
|
||||||
WAR ?= $(WASI_SDK_PATH)/bin/llvm-ar rcs
|
|
||||||
|
|
||||||
# sysroot for building wasm, default is NuttX
|
|
||||||
|
|
||||||
ifeq ($(WSYSROOT),)
|
|
||||||
WSYSROOT := $(TOPDIR)
|
|
||||||
|
|
||||||
# Force disable wasm build when WASM_SYSROOT is not defined and on specific
|
|
||||||
# targets that do not support wasm build.
|
|
||||||
# Since some architecture level inline assembly instructions can not be
|
|
||||||
# recognized by wasm-clang. For example:
|
|
||||||
# Error: /github/workspace/sources/nuttx/include/arch/chip/irq.h:220:27: error: invalid output constraint '=a' in asm
|
|
||||||
# asm volatile("rdtscp" : "=a" (lo), "=d" (hi)::"memory");
|
|
||||||
|
|
||||||
ifeq ($(CONFIG_ARCH_INTEL64)$(CONFIG_ARCH_SPARC_V8)$(CONFIG_ARCH_AVR)$(CONFIG_ARCH_XTENSA),y)
|
|
||||||
WASM_BUILD = n
|
|
||||||
endif
|
|
||||||
|
|
||||||
endif
|
|
||||||
|
|
||||||
# Only build wasm when WCC is exist
|
|
||||||
|
|
||||||
ifneq ($(wildcard $(WCC)),)
|
|
||||||
|
|
||||||
CFLAGS_STRIP = -fsanitize=kernel-address -fsanitize=address -fsanitize=undefined
|
|
||||||
CFLAGS_STRIP += $(ARCHCPUFLAGS) $(ARCHCFLAGS) $(ARCHINCLUDES) $(ARCHDEFINES) $(ARCHOPTIMIZATION) $(EXTRAFLAGS)
|
|
||||||
|
|
||||||
WCFLAGS += $(filter-out $(CFLAGS_STRIP),$(CFLAGS))
|
|
||||||
WCFLAGS += --sysroot=$(WSYSROOT) -nostdlib -D__NuttX__
|
|
||||||
|
|
||||||
# If CONFIG_LIBM not defined, then define it to 1
|
|
||||||
ifeq ($(CONFIG_LIBM),)
|
|
||||||
WCFLAGS += -DCONFIG_LIBM=1 -I$(APPDIR)$(DELIM)include$(DELIM)wasm
|
|
||||||
endif
|
|
||||||
|
|
||||||
WLDFLAGS += -z stack-size=$(STACKSIZE) -Wl,--initial-memory=$(INITIAL_MEMORY)
|
|
||||||
WLDFLAGS += -Wl,--export=main -Wl,--export=__main_argc_argv
|
|
||||||
WLDFLAGS += -Wl,--export=__heap_base -Wl,--export=__data_end
|
|
||||||
WLDFLAGS += -Wl,--no-entry -Wl,--strip-all -Wl,--allow-undefined
|
|
||||||
|
|
||||||
COMPILER_RT_LIB = $(shell $(WCC) --print-libgcc-file-name)
|
|
||||||
ifeq ($(wildcard $(COMPILER_RT_LIB)),)
|
|
||||||
# if "--print-libgcc-file-name" unable to find the correct libgcc PATH
|
|
||||||
# then go ahead and try "--print-file-name"
|
|
||||||
COMPILER_RT_LIB := $(wildcard $(shell $(WCC) --print-file-name $(notdir $(COMPILER_RT_LIB))))
|
|
||||||
endif
|
|
||||||
|
|
||||||
# If called from $(APPDIR)/Make.defs, WASM_BUILD is not defined
|
|
||||||
# Provide LINK_WASM, but only execute it when file wasm/*.wo exists
|
# Provide LINK_WASM, but only execute it when file wasm/*.wo exists
|
||||||
|
|
||||||
ifeq ($(WASM_BUILD),)
|
ifeq ($(CURDIR),$(APPDIR))
|
||||||
|
|
||||||
|
|
||||||
define LINK_WASM
|
define LINK_WASM
|
||||||
$(if $(wildcard $(APPDIR)$(DELIM)wasm$(DELIM)*), \
|
$(if $(wildcard $(APPDIR)$(DELIM)wasm$(DELIM)*), \
|
||||||
@ -86,7 +36,7 @@ define LINK_WASM
|
|||||||
$(eval INITIAL_MEMORY=$(shell echo $(notdir $(bin)) | cut -d'#' -f2)) \
|
$(eval INITIAL_MEMORY=$(shell echo $(notdir $(bin)) | cut -d'#' -f2)) \
|
||||||
$(eval STACKSIZE=$(shell echo $(notdir $(bin)) | cut -d'#' -f3)) \
|
$(eval STACKSIZE=$(shell echo $(notdir $(bin)) | cut -d'#' -f3)) \
|
||||||
$(eval PROGNAME=$(shell echo $(notdir $(bin)) | cut -d'#' -f1)) \
|
$(eval PROGNAME=$(shell echo $(notdir $(bin)) | cut -d'#' -f1)) \
|
||||||
$(eval RETVAL=$(shell $(WCC) $(bin) $(WBIN) $(WCFLAGS) $(WLDFLAGS) $(COMPILER_RT_LIB) \
|
$(eval RETVAL=$(shell $(WCC) $(bin) $(WBIN) $(WCFLAGS) $(WLDFLAGS) $(WCC_COMPILER_RT_LIB) \
|
||||||
-Wl,--Map=$(APPDIR)$(DELIM)wasm$(DELIM)$(PROGNAME).map \
|
-Wl,--Map=$(APPDIR)$(DELIM)wasm$(DELIM)$(PROGNAME).map \
|
||||||
-o $(APPDIR)$(DELIM)wasm$(DELIM)$(PROGNAME).wasm || echo 1;)) \
|
-o $(APPDIR)$(DELIM)wasm$(DELIM)$(PROGNAME).wasm || echo 1;)) \
|
||||||
$(if $(RETVAL), \
|
$(if $(RETVAL), \
|
||||||
@ -97,15 +47,13 @@ define LINK_WASM
|
|||||||
)
|
)
|
||||||
endef
|
endef
|
||||||
|
|
||||||
endif # WASM_BUILD
|
endif # CURDIR
|
||||||
|
|
||||||
# Default values for WASM_BUILD, it's a three state variable:
|
# Default values for WASM_BUILD, it's a three state variable:
|
||||||
# y - build wasm module only
|
# y - build wasm module only
|
||||||
# n - don't build wasm module
|
# n - don't build wasm module, default
|
||||||
# both - build wasm module and native module
|
# both - build wasm module and native module
|
||||||
|
|
||||||
WASM_BUILD ?= n
|
|
||||||
|
|
||||||
ifneq ($(WASM_BUILD),n)
|
ifneq ($(WASM_BUILD),n)
|
||||||
|
|
||||||
WASM_INITIAL_MEMORY ?= 65536
|
WASM_INITIAL_MEMORY ?= 65536
|
||||||
@ -160,5 +108,4 @@ clean::
|
|||||||
|
|
||||||
endif # WASM_BUILD
|
endif # WASM_BUILD
|
||||||
|
|
||||||
endif # WCC
|
endif # CONFIG_INTERPRETERS_WAMR || CONFIG_INTERPRETERS_WASM || CONFIG_INTERPRETERS_TOYWASM
|
||||||
endif
|
|
||||||
|
Loading…
Reference in New Issue
Block a user