|
|
|
# where py object files go (they have a name prefix to prevent filename clashes)
|
|
|
|
PY_BUILD = $(BUILD)/py
|
|
|
|
|
|
|
|
# where autogenerated header files go
|
|
|
|
HEADER_BUILD = $(BUILD)/genhdr
|
|
|
|
|
|
|
|
# file containing qstr defs for the core Python bit
|
|
|
|
PY_QSTR_DEFS = $(PY_SRC)/qstrdefs.h
|
|
|
|
|
|
|
|
# If qstr autogeneration is not disabled we specify the output header
|
|
|
|
# for all collected qstrings.
|
|
|
|
ifneq ($(QSTR_AUTOGEN_DISABLE),1)
|
py: Add rules for automated extraction of qstrs from sources.
- add template rule that converts a specified source file into a qstring file
- add special rule for generating a central header that contains all
extracted/autogenerated strings - defined by QSTR_DEFS_COLLECTED
variable. Each platform appends a list of sources that may contain
qstrings into a new build variable: SRC_QSTR. Any autogenerated
prerequisities are should be appened to SRC_QSTR_AUTO_DEPS variable.
- remove most qstrings from py/qstrdefs, keep only qstrings that
contain special characters - these cannot be easily detected in the
sources without additional annotations
- remove most manual qstrdefs, use qstrdef autogen for: py, cc3200,
stmhal, teensy, unix, windows, pic16bit:
- remove all micropython generic qstrdefs except for the special strings that contain special characters (e.g. /,+,<,> etc.)
- remove all port specific qstrdefs except for special strings
- append sources for qstr generation in platform makefiles (SRC_QSTR)
9 years ago
|
|
|
QSTR_DEFS_COLLECTED = $(HEADER_BUILD)/qstrdefs.collected.h
|
|
|
|
endif
|
py: Add rules for automated extraction of qstrs from sources.
- add template rule that converts a specified source file into a qstring file
- add special rule for generating a central header that contains all
extracted/autogenerated strings - defined by QSTR_DEFS_COLLECTED
variable. Each platform appends a list of sources that may contain
qstrings into a new build variable: SRC_QSTR. Any autogenerated
prerequisities are should be appened to SRC_QSTR_AUTO_DEPS variable.
- remove most qstrings from py/qstrdefs, keep only qstrings that
contain special characters - these cannot be easily detected in the
sources without additional annotations
- remove most manual qstrdefs, use qstrdef autogen for: py, cc3200,
stmhal, teensy, unix, windows, pic16bit:
- remove all micropython generic qstrdefs except for the special strings that contain special characters (e.g. /,+,<,> etc.)
- remove all port specific qstrdefs except for special strings
- append sources for qstr generation in platform makefiles (SRC_QSTR)
9 years ago
|
|
|
|
|
|
|
# Any files listed by these variables will cause a full regeneration of qstrs
|
|
|
|
# DEPENDENCIES: included in qstr processing; REQUIREMENTS: not included
|
|
|
|
QSTR_GLOBAL_DEPENDENCIES += $(PY_SRC)/mpconfig.h mpconfigport.h
|
|
|
|
QSTR_GLOBAL_REQUIREMENTS += $(HEADER_BUILD)/mpversion.h
|
|
|
|
|
|
|
|
# some code is performance bottleneck and compiled with other optimization options
|
|
|
|
CSUPEROPT = -O3
|
|
|
|
|
|
|
|
# Enable building 32-bit code on 64-bit host.
|
|
|
|
ifeq ($(MICROPY_FORCE_32BIT),1)
|
|
|
|
CC += -m32
|
|
|
|
CXX += -m32
|
|
|
|
LD += -m32
|
|
|
|
endif
|
|
|
|
|
|
|
|
# External modules written in C.
|
|
|
|
ifneq ($(USER_C_MODULES),)
|
|
|
|
# pre-define USERMOD variables as expanded so that variables are immediate
|
|
|
|
# expanded as they're added to them
|
|
|
|
|
|
|
|
# C/C++ files that are included in the QSTR/module build
|
|
|
|
SRC_USERMOD_C :=
|
|
|
|
SRC_USERMOD_CXX :=
|
|
|
|
# Other C/C++ files (e.g. libraries or helpers)
|
|
|
|
SRC_USERMOD_LIB_C :=
|
|
|
|
SRC_USERMOD_LIB_CXX :=
|
|
|
|
# Optionally set flags
|
|
|
|
CFLAGS_USERMOD :=
|
|
|
|
CXXFLAGS_USERMOD :=
|
|
|
|
LDFLAGS_USERMOD :=
|
|
|
|
|
|
|
|
# Backwards compatibility with older user c modules that set SRC_USERMOD
|
|
|
|
# added to SRC_USERMOD_C below
|
|
|
|
SRC_USERMOD :=
|
|
|
|
|
|
|
|
$(foreach module, $(wildcard $(USER_C_MODULES)/*/micropython.mk), \
|
|
|
|
$(eval USERMOD_DIR = $(patsubst %/,%,$(dir $(module))))\
|
|
|
|
$(info Including User C Module from $(USERMOD_DIR))\
|
|
|
|
$(eval include $(module))\
|
|
|
|
)
|
|
|
|
|
|
|
|
SRC_USERMOD_C += $(SRC_USERMOD)
|
|
|
|
|
|
|
|
SRC_USERMOD_PATHFIX_C += $(patsubst $(USER_C_MODULES)/%.c,%.c,$(SRC_USERMOD_C))
|
|
|
|
SRC_USERMOD_PATHFIX_CXX += $(patsubst $(USER_C_MODULES)/%.cpp,%.cpp,$(SRC_USERMOD_CXX))
|
|
|
|
SRC_USERMOD_PATHFIX_LIB_C += $(patsubst $(USER_C_MODULES)/%.c,%.c,$(SRC_USERMOD_LIB_C))
|
|
|
|
SRC_USERMOD_PATHFIX_LIB_CXX += $(patsubst $(USER_C_MODULES)/%.cpp,%.cpp,$(SRC_USERMOD_LIB_CXX))
|
|
|
|
|
|
|
|
CFLAGS += $(CFLAGS_USERMOD)
|
|
|
|
CXXFLAGS += $(CXXFLAGS_USERMOD)
|
|
|
|
LDFLAGS += $(LDFLAGS_USERMOD)
|
|
|
|
|
|
|
|
SRC_QSTR += $(SRC_USERMOD_PATHFIX_C) $(SRC_USERMOD_PATHFIX_CXX)
|
|
|
|
PY_O += $(addprefix $(BUILD)/, $(SRC_USERMOD_PATHFIX_C:.c=.o))
|
|
|
|
PY_O += $(addprefix $(BUILD)/, $(SRC_USERMOD_PATHFIX_CXX:.cpp=.o))
|
|
|
|
PY_O += $(addprefix $(BUILD)/, $(SRC_USERMOD_PATHFIX_LIB_C:.c=.o))
|
|
|
|
PY_O += $(addprefix $(BUILD)/, $(SRC_USERMOD_PATHFIX_LIB_CXX:.cpp=.o))
|
|
|
|
endif
|
|
|
|
|
|
|
|
# py object files
|
|
|
|
PY_CORE_O_BASENAME = $(addprefix py/,\
|
|
|
|
mpstate.o \
|
|
|
|
nlr.o \
|
|
|
|
nlrx86.o \
|
|
|
|
nlrx64.o \
|
|
|
|
nlrthumb.o \
|
|
|
|
nlraarch64.o \
|
|
|
|
nlrmips.o \
|
|
|
|
nlrpowerpc.o \
|
|
|
|
nlrxtensa.o \
|
|
|
|
nlrsetjmp.o \
|
|
|
|
malloc.o \
|
|
|
|
gc.o \
|
py: Introduce a Python stack for scoped allocation.
This patch introduces the MICROPY_ENABLE_PYSTACK option (disabled by
default) which enables a "Python stack" that allows to allocate and free
memory in a scoped, or Last-In-First-Out (LIFO) way, similar to alloca().
A new memory allocation API is introduced along with this Py-stack. It
includes both "local" and "nonlocal" LIFO allocation. Local allocation is
intended to be equivalent to using alloca(), whereby the same function must
free the memory. Nonlocal allocation is where another function may free
the memory, so long as it's still LIFO.
Follow-up patches will convert all uses of alloca() and VLA to the new
scoped allocation API. The old behaviour (using alloca()) will still be
available, but when MICROPY_ENABLE_PYSTACK is enabled then alloca() is no
longer required or used.
The benefits of enabling this option are (or will be once subsequent
patches are made to convert alloca()/VLA):
- Toolchains without alloca() can use this feature to obtain correct and
efficient scoped memory allocation (compared to using the heap instead
of alloca(), which is slower).
- Even if alloca() is available, enabling the Py-stack gives slightly more
efficient use of stack space when calling nested Python functions, due to
the way that compilers implement alloca().
- Enabling the Py-stack with the stackless mode allows for even more
efficient stack usage, as well as retaining high performance (because the
heap is no longer used to build and destroy stackless code states).
- With Py-stack and stackless enabled, Python-calling-Python is no longer
recursive in the C mp_execute_bytecode function.
The micropython.pystack_use() function is included to measure usage of the
Python stack.
7 years ago
|
|
|
pystack.o \
|
|
|
|
qstr.o \
|
|
|
|
vstr.o \
|
|
|
|
mpprint.o \
|
|
|
|
unicode.o \
|
|
|
|
mpz.o \
|
|
|
|
reader.o \
|
|
|
|
lexer.o \
|
|
|
|
parse.o \
|
|
|
|
scope.o \
|
|
|
|
compile.o \
|
|
|
|
emitcommon.o \
|
|
|
|
emitbc.o \
|
|
|
|
asmbase.o \
|
|
|
|
asmx64.o \
|
|
|
|
emitnx64.o \
|
|
|
|
asmx86.o \
|
|
|
|
emitnx86.o \
|
|
|
|
asmthumb.o \
|
|
|
|
emitnthumb.o \
|
|
|
|
emitinlinethumb.o \
|
|
|
|
asmarm.o \
|
|
|
|
emitnarm.o \
|
|
|
|
asmxtensa.o \
|
|
|
|
emitnxtensa.o \
|
py: Add inline Xtensa assembler.
This patch adds the MICROPY_EMIT_INLINE_XTENSA option, which, when
enabled, allows the @micropython.asm_xtensa decorator to be used.
The following opcodes are currently supported (ax is a register, a0-a15):
ret_n()
callx0(ax)
j(label)
jx(ax)
beqz(ax, label)
bnez(ax, label)
mov(ax, ay)
movi(ax, imm) # imm can be full 32-bit, uses l32r if needed
and_(ax, ay, az)
or_(ax, ay, az)
xor(ax, ay, az)
add(ax, ay, az)
sub(ax, ay, az)
mull(ax, ay, az)
l8ui(ax, ay, imm)
l16ui(ax, ay, imm)
l32i(ax, ay, imm)
s8i(ax, ay, imm)
s16i(ax, ay, imm)
s32i(ax, ay, imm)
l16si(ax, ay, imm)
addi(ax, ay, imm)
ball(ax, ay, label)
bany(ax, ay, label)
bbc(ax, ay, label)
bbs(ax, ay, label)
beq(ax, ay, label)
bge(ax, ay, label)
bgeu(ax, ay, label)
blt(ax, ay, label)
bnall(ax, ay, label)
bne(ax, ay, label)
bnone(ax, ay, label)
Upon entry to the assembly function the registers a0, a12, a13, a14 are
pushed to the stack and the stack pointer (a1) decreased by 16. Upon
exit, these registers and the stack pointer are restored, and ret.n is
executed to return to the caller (caller address is in a0).
Note that the ABI for the Xtensa emitters is non-windowing.
8 years ago
|
|
|
emitinlinextensa.o \
|
|
|
|
emitnxtensawin.o \
|
|
|
|
formatfloat.o \
|
|
|
|
parsenumbase.o \
|
|
|
|
parsenum.o \
|
|
|
|
emitglue.o \
|
|
|
|
persistentcode.o \
|
|
|
|
runtime.o \
|
|
|
|
runtime_utils.o \
|
|
|
|
scheduler.o \
|
|
|
|
nativeglue.o \
|
|
|
|
pairheap.o \
|
|
|
|
ringbuf.o \
|
|
|
|
stackctrl.o \
|
|
|
|
argcheck.o \
|
|
|
|
warning.o \
|
|
|
|
profile.o \
|
|
|
|
map.o \
|
|
|
|
obj.o \
|
|
|
|
objarray.o \
|
|
|
|
objattrtuple.o \
|
|
|
|
objbool.o \
|
|
|
|
objboundmeth.o \
|
|
|
|
objcell.o \
|
|
|
|
objclosure.o \
|
|
|
|
objcomplex.o \
|
|
|
|
objdeque.o \
|
|
|
|
objdict.o \
|
|
|
|
objenumerate.o \
|
|
|
|
objexcept.o \
|
|
|
|
objfilter.o \
|
|
|
|
objfloat.o \
|
|
|
|
objfun.o \
|
|
|
|
objgenerator.o \
|
|
|
|
objgetitemiter.o \
|
|
|
|
objint.o \
|
|
|
|
objint_longlong.o \
|
|
|
|
objint_mpz.o \
|
|
|
|
objlist.o \
|
|
|
|
objmap.o \
|
|
|
|
objmodule.o \
|
|
|
|
objobject.o \
|
|
|
|
objpolyiter.o \
|
|
|
|
objproperty.o \
|
|
|
|
objnone.o \
|
|
|
|
objnamedtuple.o \
|
|
|
|
objrange.o \
|
|
|
|
objreversed.o \
|
|
|
|
objset.o \
|
|
|
|
objsingleton.o \
|
|
|
|
objslice.o \
|
|
|
|
objstr.o \
|
|
|
|
objstrunicode.o \
|
|
|
|
objstringio.o \
|
|
|
|
objtuple.o \
|
|
|
|
objtype.o \
|
|
|
|
objzip.o \
|
|
|
|
opmethods.o \
|
|
|
|
sequence.o \
|
|
|
|
stream.o \
|
|
|
|
binary.o \
|
|
|
|
builtinimport.o \
|
|
|
|
builtinevex.o \
|
|
|
|
builtinhelp.o \
|
|
|
|
modarray.o \
|
|
|
|
modbuiltins.o \
|
|
|
|
modcollections.o \
|
|
|
|
modgc.o \
|
|
|
|
modio.o \
|
|
|
|
modmath.o \
|
|
|
|
modcmath.o \
|
|
|
|
modmicropython.o \
|
|
|
|
modstruct.o \
|
|
|
|
modsys.o \
|
|
|
|
moduerrno.o \
|
|
|
|
modthread.o \
|
|
|
|
vm.o \
|
|
|
|
bc.o \
|
|
|
|
showbc.o \
|
|
|
|
repl.o \
|
|
|
|
smallint.o \
|
|
|
|
frozenmod.o \
|
|
|
|
)
|
|
|
|
|
|
|
|
# prepend the build destination prefix to the py object files
|
|
|
|
PY_CORE_O = $(addprefix $(BUILD)/, $(PY_CORE_O_BASENAME))
|
|
|
|
|
|
|
|
# this is a convenience variable for ports that want core, extmod and frozen code
|
|
|
|
PY_O += $(PY_CORE_O)
|
|
|
|
|
|
|
|
# object file for frozen code specified via a manifest
|
|
|
|
ifneq ($(FROZEN_MANIFEST),)
|
|
|
|
PY_O += $(BUILD)/$(BUILD)/frozen_content.o
|
|
|
|
endif
|
|
|
|
|
py: Add rules for automated extraction of qstrs from sources.
- add template rule that converts a specified source file into a qstring file
- add special rule for generating a central header that contains all
extracted/autogenerated strings - defined by QSTR_DEFS_COLLECTED
variable. Each platform appends a list of sources that may contain
qstrings into a new build variable: SRC_QSTR. Any autogenerated
prerequisities are should be appened to SRC_QSTR_AUTO_DEPS variable.
- remove most qstrings from py/qstrdefs, keep only qstrings that
contain special characters - these cannot be easily detected in the
sources without additional annotations
- remove most manual qstrdefs, use qstrdef autogen for: py, cc3200,
stmhal, teensy, unix, windows, pic16bit:
- remove all micropython generic qstrdefs except for the special strings that contain special characters (e.g. /,+,<,> etc.)
- remove all port specific qstrdefs except for special strings
- append sources for qstr generation in platform makefiles (SRC_QSTR)
9 years ago
|
|
|
# Sources that may contain qstrings
|
|
|
|
SRC_QSTR_IGNORE = py/nlr%
|
extmod: Make extmod.mk self-contained.
This makes it so that all a port needs to do is set the relevant variables
and "include extmod.mk" and doesn't need to worry about adding anything to
OBJ, CFLAGS, SRC_QSTR, etc.
Make all extmod variables (src, flags, etc) private to extmod.mk.
Also move common/shared, extmod-related fragments (e.g. wiznet, cyw43,
bluetooth) into extmod.mk.
Now that SRC_MOD, CFLAGS_MOD, CXXFLAGS_MOD are unused by both extmod.mk
(and user-C-modules in a previous commit), remove all uses of them from
port makefiles.
Signed-off-by: Jim Mussared <jim.mussared@gmail.com>
2 years ago
|
|
|
SRC_QSTR += $(filter-out $(SRC_QSTR_IGNORE),$(PY_CORE_O_BASENAME:.o=.c))
|
py: Add rules for automated extraction of qstrs from sources.
- add template rule that converts a specified source file into a qstring file
- add special rule for generating a central header that contains all
extracted/autogenerated strings - defined by QSTR_DEFS_COLLECTED
variable. Each platform appends a list of sources that may contain
qstrings into a new build variable: SRC_QSTR. Any autogenerated
prerequisities are should be appened to SRC_QSTR_AUTO_DEPS variable.
- remove most qstrings from py/qstrdefs, keep only qstrings that
contain special characters - these cannot be easily detected in the
sources without additional annotations
- remove most manual qstrdefs, use qstrdef autogen for: py, cc3200,
stmhal, teensy, unix, windows, pic16bit:
- remove all micropython generic qstrdefs except for the special strings that contain special characters (e.g. /,+,<,> etc.)
- remove all port specific qstrdefs except for special strings
- append sources for qstr generation in platform makefiles (SRC_QSTR)
9 years ago
|
|
|
|
|
|
|
# Anything that depends on FORCE will be considered out-of-date
|
|
|
|
FORCE:
|
|
|
|
.PHONY: FORCE
|
|
|
|
|
|
|
|
$(HEADER_BUILD)/mpversion.h: FORCE | $(HEADER_BUILD)
|
|
|
|
$(Q)$(PYTHON) $(PY_SRC)/makeversionhdr.py $@
|
|
|
|
|
|
|
|
# mpconfigport.mk is optional, but changes to it may drastically change
|
|
|
|
# overall config, so they need to be caught
|
|
|
|
MPCONFIGPORT_MK = $(wildcard mpconfigport.mk)
|
|
|
|
|
|
|
|
# qstr data
|
|
|
|
# Adding an order only dependency on $(HEADER_BUILD) causes $(HEADER_BUILD) to get
|
|
|
|
# created before we run the script to generate the .h
|
|
|
|
# Note: we need to protect the qstr names from the preprocessor, so we wrap
|
|
|
|
# the lines in "" and then unwrap after the preprocessor is finished.
|
|
|
|
# See more information about this process in docs/develop/qstr.rst.
|
py: Add rules for automated extraction of qstrs from sources.
- add template rule that converts a specified source file into a qstring file
- add special rule for generating a central header that contains all
extracted/autogenerated strings - defined by QSTR_DEFS_COLLECTED
variable. Each platform appends a list of sources that may contain
qstrings into a new build variable: SRC_QSTR. Any autogenerated
prerequisities are should be appened to SRC_QSTR_AUTO_DEPS variable.
- remove most qstrings from py/qstrdefs, keep only qstrings that
contain special characters - these cannot be easily detected in the
sources without additional annotations
- remove most manual qstrdefs, use qstrdef autogen for: py, cc3200,
stmhal, teensy, unix, windows, pic16bit:
- remove all micropython generic qstrdefs except for the special strings that contain special characters (e.g. /,+,<,> etc.)
- remove all port specific qstrdefs except for special strings
- append sources for qstr generation in platform makefiles (SRC_QSTR)
9 years ago
|
|
|
$(HEADER_BUILD)/qstrdefs.generated.h: $(PY_QSTR_DEFS) $(QSTR_DEFS) $(QSTR_DEFS_COLLECTED) $(PY_SRC)/makeqstrdata.py mpconfigport.h $(MPCONFIGPORT_MK) $(PY_SRC)/mpconfig.h | $(HEADER_BUILD)
|
|
|
|
$(ECHO) "GEN $@"
|
|
|
|
$(Q)$(CAT) $(PY_QSTR_DEFS) $(QSTR_DEFS) $(QSTR_DEFS_COLLECTED) | $(SED) 's/^Q(.*)/"&"/' | $(CPP) $(CFLAGS) - | $(SED) 's/^\"\(Q(.*)\)\"/\1/' > $(HEADER_BUILD)/qstrdefs.preprocessed.h
|
|
|
|
$(Q)$(PYTHON) $(PY_SRC)/makeqstrdata.py $(HEADER_BUILD)/qstrdefs.preprocessed.h > $@
|
|
|
|
|
py: Implement "common word" compression scheme for error messages.
The idea here is that there's a moderate amount of ROM used up by exception
text. Obviously we try to keep the messages short, and the code can enable
terse errors, but it still adds up. Listed below is the total string data
size for various ports:
bare-arm 2860
minimal 2876
stm32 8926 (PYBV11)
cc3200 3751
esp32 5721
This commit implements compression of these strings. It takes advantage of
the fact that these strings are all 7-bit ascii and extracts the top 128
frequently used words from the messages and stores them packed (dropping
their null-terminator), then uses (0x80 | index) inside strings to refer to
these common words. Spaces are automatically added around words, saving
more bytes. This happens transparently in the build process, mirroring the
steps that are used to generate the QSTR data. The MP_COMPRESSED_ROM_TEXT
macro wraps any literal string that should compressed, and it's
automatically decompressed in mp_decompress_rom_string.
There are many schemes that could be used for the compression, and some are
included in py/makecompresseddata.py for reference (space, Huffman, ngram,
common word). Results showed that the common-word compression gets better
results. This is before counting the increased cost of the Huffman
decoder. This might be slightly counter-intuitive, but this data is
extremely repetitive at a word-level, and the byte-level entropy coder
can't quite exploit that as efficiently. Ideally one would combine both
approaches, but for now the common-word approach is the one that is used.
For additional comparison, the size of the raw data compressed with gzip
and zlib is calculated, as a sort of proxy for a lower entropy bound. With
this scheme we come within 15% on stm32, and 30% on bare-arm (i.e. we use
x% more bytes than the data compressed with gzip -- not counting the code
overhead of a decoder, and how this would be hypothetically implemented).
The feature is disabled by default and can be enabled by setting
MICROPY_ROM_TEXT_COMPRESSION at the Makefile-level.
5 years ago
|
|
|
$(HEADER_BUILD)/compressed.data.h: $(HEADER_BUILD)/compressed.collected
|
|
|
|
$(ECHO) "GEN $@"
|
|
|
|
$(Q)$(PYTHON) $(PY_SRC)/makecompresseddata.py $< > $@
|
|
|
|
|
|
|
|
# build a list of registered modules for py/objmodule.c.
|
|
|
|
$(HEADER_BUILD)/moduledefs.h: $(HEADER_BUILD)/moduledefs.collected
|
|
|
|
@$(ECHO) "GEN $@"
|
|
|
|
$(Q)$(PYTHON) $(PY_SRC)/makemoduledefs.py $< > $@
|
|
|
|
|
|
|
|
# build a list of registered root pointers for py/mpstate.h.
|
|
|
|
$(HEADER_BUILD)/root_pointers.h: $(HEADER_BUILD)/root_pointers.collected $(PY_SRC)/make_root_pointers.py
|
|
|
|
@$(ECHO) "GEN $@"
|
|
|
|
$(Q)$(PYTHON) $(PY_SRC)/make_root_pointers.py $< > $@
|
|
|
|
|
|
|
|
# Standard C functions like memset need to be compiled with special flags so
|
|
|
|
# the compiler does not optimise these functions in terms of themselves.
|
|
|
|
CFLAGS_BUILTIN ?= -ffreestanding -fno-builtin -fno-lto
|
|
|
|
$(BUILD)/shared/libc/string0.o: CFLAGS += $(CFLAGS_BUILTIN)
|
|
|
|
|
|
|
|
# Force nlr code to always be compiled with space-saving optimisation so
|
|
|
|
# that the function preludes are of a minimal and predictable form.
|
|
|
|
$(PY_BUILD)/nlr%.o: CFLAGS += -Os
|
|
|
|
|
|
|
|
# optimising gc for speed; 5ms down to 4ms on pybv2
|
|
|
|
$(PY_BUILD)/gc.o: CFLAGS += $(CSUPEROPT)
|
|
|
|
|
|
|
|
# optimising vm for speed, adds only a small amount to code size but makes a huge difference to speed (20% faster)
|
|
|
|
$(PY_BUILD)/vm.o: CFLAGS += $(CSUPEROPT)
|
|
|
|
# Optimizing vm.o for modern deeply pipelined CPUs with branch predictors
|
|
|
|
# may require disabling tail jump optimization. This will make sure that
|
|
|
|
# each opcode has its own dispatching jump which will improve branch
|
|
|
|
# branch predictor efficiency.
|
|
|
|
# https://marc.info/?l=lua-l&m=129778596120851
|
|
|
|
# http://hg.python.org/cpython/file/b127046831e2/Python/ceval.c#l828
|
|
|
|
# http://www.emulators.com/docs/nx25_nostradamus.htm
|
|
|
|
#-fno-crossjumping
|