-
-
Notifications
You must be signed in to change notification settings - Fork 1.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
remove native nasm #6263
base: master
Are you sure you want to change the base?
remove native nasm #6263
Conversation
- remove native nasm, it is a prerequisite in the dev. environment since update to debian 12 - remove native yasm - update related Makefiles
This reverts commit 2c4a9cb.
- change affected packages to trigger build
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Beside possible issue found with openh264
that your change brought to light, LGTM.
- update cross/dav1d - remove definitions for nasm, meson build completely auto detects nasm
- remove definitions for nasm, meson build completely auto detects nasm - create optimized code
- cmake builds completely auto detect nasm
Special NASM definitions for meson and cmake build systems are obsolete and removed now. further analysis for gcc builds (spksrc.cross-cc.mk) is WIP. |
- disable support for OLD_PPC_ARCHS - build with assembler, except for PPC_ARCHS - remove obsolete configure args --enable-pic is forced with --enable-shared --cross-prefix is not required - remove definition of GNU_CONFIGURE and define --host - simplify definition of gcc as assembler if not using x86asm
- define --as=auto to use yasmm (prefered over nasm) - document why we don't define GNU_CONFIGRE - remove concurring patch - avoid duplicate definition of --disable-neon
@th0ma7 the libraries and *.mk files are ready for review. On the ffmpeg* packages there is some pending work...
|
and the third issue is with even we configure with |
CONFIGURE_ARGS += -Denable_asm=true | ||
|
||
# Allow ASM on aarch64, disable on all others | ||
else ifeq ($(findstring $(ARCH),$(ARMv8_ARCHS)),$(ARCH)) | ||
CONFIGURE_ARGS += -Denable_asm=true | ||
else | ||
CONFIGURE_ARGS += -Denable_asm=false |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nasm is only used for x86/x86_64, while for aarch64 it uses the gcc assembler (as
). Considering the code above, you should have kept something such as:
ifeq ($(findstring $(ARCH),$(ARMv8_ARCHS) $(i686_ARCHS) $(x64_ARCHS)),$(ARCH))
CONFIGURE_ARGS += -Denable_asm=true
else
CONFIGURE_ARGS += -Denable_asm=false
endif
While it probably builds ok, I recall code to fail on armv7 in multiple cases which led to enable assembly optimizations only on aarch64 and x86 archs. I would suggest keeping this ifeq else usecase (and maybe elsewhere, haven't looked at all the code changes).
EDIT: On another comment I realized that issues with as
on armv7 related to gcc <= 4.9, rather suggesting:
include ../../mk/spksrc.common.mk
ifeq ($(findstring $(ARCH),$(ARMv8_ARCHS) $(i686_ARCHS) $(x64_ARCHS)),$(ARCH))
CONFIGURE_ARGS += -Denable_asm=true
# only enable `asm` on armv7 when using gcc > 4.9.* (i.e. DSM7+)
else if ($(findstring $(ARCH),$(ARMv7_ARCHS) $(ARMv7L_ARCHS)),$(ARCH))
ifeq ($(call version_lt, ${TC_GCC}, 5),1)
CONFIGURE_ARGS += -Denable_asm=true
endif
else
CONFIGURE_ARGS += -Denable_asm=false
endif
@@ -15,14 +15,10 @@ LICENSE = BSD | |||
UNSUPPORTED_ARCHS = $(PPC_ARCHS) | |||
|
|||
CONFIGURE_ARGS += -Dtests=disabled | |||
ADDITIONAL_CPPFLAGS = -O |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why? is it to diable optimizations (i.e. -O0
)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why? is it to diable optimizations (i.e.
-O0
)
no -O
is the same as -O1
= optimization for code size and execution time
a kind of default optimization.
my favorite for cross packages is -O2
gcc -O option flag
Set the compiler's optimization level.
option | optimization level | execution time | code size | memory usage | compile time |
---|---|---|---|---|---|
-O0 | optimization for compilation time (default) | + | + | - | - |
-O1 or -O | optimization for code size and execution time | - | - | + | + |
-O2 | optimization more for code size and execution time | -- | + | ++ | |
-O3 | optimization more for code size and execution time | --- | + | +++ | |
-Os | optimization for code size | -- | ++ | ||
-Ofast | O3 with fast none accurate math calculations | --- | + | +++ |
<p>+increase ++increase more +++increase even more -reduce --reduce more
---reduce even more</p><!--EndFragment-->
# Define x86asm or use gcc as assembler | ||
ifeq ($(findstring $(ARCH),$(i686_ARCHS) $(x64_ARCHS)),$(ARCH)) | ||
NASM_BINARY = $(shell which nasm) | ||
ifeq ($(NASM_BINARY),) | ||
$(error nasm not found. Please install NASM assembler) | ||
endif | ||
ENV += AS=$(NASM_BINARY) | ||
else |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Similarly to ffmpeg, isn't this too much as nasm is always installed?
If anything, I'd rather have that test being done outside from individual cross but within the framework to avoid code duplication if feasible.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
cross/x264/Makefile
is the only file that needs nasm binary to define AS
.
I did a first pass, overall looking good. However I believe it does require minor adjustments for armv7 with gcc <= 4.9.x pertaining to assembly optimizations (i.e. neon).
I would suggest removing
Wow, that brings me a while back... when I took over the ffmpeg maintenance (which I didn't new what I was up against), I thought we absolutely needed arch specific packages for acceleration purposes... Not totally wrong but unsustainable as we a) don't have the manpower to support that (and not sure of the benefits) and b) don't have the storage space to do so. Honestly this can be cleaned-up, it's just crap left-over. Good catch thoughg 🤷 |
I tried enabling the following options to check if nasm would be used somewhere, but nothing (btw, nevertless, mp3rtp could be enabled with the addition of
Looking at arch linux and gentoo they both enable nasm...? Even default debian rules files enables it. btw
Tried them all, nothing shows up from a nasm usage ... So I tried compiling on the host to see what hapens, and it does enter into
Honestly, I don't believe it ever worked or I'm missing something? |
- it is not possible to enable or disable the use of nasm
@th0ma7 I have investigated further for |
- we will never build alpine or monaco specific ffmpeg* packages - ffmpeg4: remove nasm path definitions
Description
Fixes #
Affected Libraries
Direct dependencies
Further findings
Affected Packages
By direct dependencies
Checklist
all-supported
completed successfullyType of change