Ignoring 'target specific option mismatch' on inline

J.W. Jagersma jwjagersma@gmail.com
Wed Oct 12 21:44:14 GMT 2022


Consider the following (incomplete) code:

    enum simd { mmx = 1, sse = 2 /* , ... */ };

    template<simd flags>
    void simd_func()
    {
        if constexpr (flags & simd::mmx)
        {
            // MMX code here
        }
        else if constexpr (flags & simd::sse)
        {
            // SSE code here
        }
        // etc ...
    }

The idea is to instantiate function templates with optimized SIMD routines
multiple times, then I can compile all my code with -march=i386, and select the
best implementation at runtime.

However, after already spending a lot of time restructuring my code around this
idea, I discover that gcc refuses to compile this without having the
corresponding target options enabled:

    error: inlining failed in call to 'always_inline' '__m64 _mm_unpacklo_pi8(__m64, __m64)': target specific option mismatch

That makes no sense to me.  I want gcc to emit those SIMD instructions verbatim
in my code, regardless of what compiler options the user specified.  What then
is the point of feature-test macros (__SSE__, etc)?  I don't get it.

Is there any option or attribute I can use to make gcc ignore these target
option mismatches when inlining?  Or any other way to make this work?


More information about the Gcc-help mailing list