www/firefox, Error: garbage following instruction...was: Re: RPI2, www/firefox, error: "NEON support not enabled"

Michal Meloun melounmichal at gmail.com
Mon May 8 11:08:46 UTC 2017


On 08.05.2017 10:56, Dimitry Andric wrote:
> On 8 May 2017, at 05:33, bob prohaska <fbsd at www.zefox.net> wrote:
>>
>> On Fri, May 05, 2017 at 10:01:40PM -0700, bob prohaska wrote:
>>> It appears that using
>>> make CFLAGS='-mcpu=cortex-a7'
>>> is sufficient to get past the NEON not enabled  error.
>>>
>>
>> The next problem appears to be
>>
>>
>>
/usr/ports/www/firefox/work/firefox-53.0.2/media/openmax_dl/dl/sp/src/armSP_FFT_CToC_FC32_Radix4_ls_unsafe_s.S:335:
Error: garbage following instruction -- `vmov Q7.F32,Q0.F32'
>> cc: error: assembler command failed with exit code 1 (use -v to see
invocation)
>> gmake[6]: ***
[/usr/ports/www/firefox/work/firefox-53.0.2/config/rules.mk:990:
armSP_FFT_CToC_FC32_Radix4_ls_unsafe_s.o] Error 1
>> gmake[5]: ***
[/usr/ports/www/firefox/work/firefox-53.0.2/config/recurse.mk:71:
media/openmax_dl/dl/target] Error 2
>>
>> Is this worth a bug report, or is firefox too far over the horizon
>> for freebsd-arm?
>>
>> Thanks for reading, and any guidance.
>
> This is actually an error message from the GNU assembler, which is
> invoked by the compiler driver.  Can you figure out whether it is the
> base version (/usr/bin/as) or the ports version (/usr/local/bin/as)?
> E.g. manually run that command line with -v, so see which assembler it
> runs.
>
> Also, I wonder why they don't use the integrated assembler in clang, but
> that is an aspect of the firefox port I'm not familiar with.
>
> -Dimitry
>
It's from base (buggy, outdated) GNU assembler, gas from ports can
compile affected file without problem.

The integrated clang assembler cannot be used because Mozilla extensive
uses macros in assembly code, and macros are not supported by clang.
Moreover, many pieces of assembly files still uses pre-UAL syntax.

Unfortunately, replacing base as (by the one from port) is not
sufficient - the Mozilla build system doesn't pass external CFLAGS to
assembly files (.S), so build fails again later.

Michal


More information about the freebsd-arm mailing list