[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Xen-devel] [PATCH 2/2] x86: fix indirect thunk usage of CONFIG_INDIRECT_THUNK



On Wed, Jan 24, 2018 at 04:52:17PM +0000, Roger Pau Monné wrote:
> On Wed, Jan 24, 2018 at 09:23:37AM -0700, Jan Beulich wrote:
> > >>> On 24.01.18 at 16:48, <roger.pau@xxxxxxxxxx> wrote:
> > > When indirect_thunk_asm.h is instantiated directly into assembly files
> > > CONFIG_INDIRECT_THUNK might not be defined, and thus using .if against
> > > it is wrong.
> > > 
> > > Add a check to define CONFIG_INDIRECT_THUNK to 0 if not defined, so
> > > that using .if CONFIG_INDIRECT_THUNK is always correct.
> > > 
> > > This suppresses the following clang error:
> > > 
> > > <instantiation>:8:9: error: expected absolute expression
> > >     .if CONFIG_INDIRECT_THUNK == 1
> > >         ^
> > > <instantiation>:1:1: note: while in macro instantiation
> > > INDIRECT_BRANCH call %rdx
> > > ^
> > > entry.S:589:9: note: while in macro instantiation
> > >         INDIRECT_CALL %rdx
> > >         ^
> > 
> > Why is the same no problem with gas? It wants constant
> > expressions with .if too, after all.
> 
> Right, and I cannot figure out why it works when using
> -no-integrated-as and not when not using it. The more that I cannot
> see CONFIG_INDIRECT_THUNK being unconditionally defined to either 0 or
> 1. I guess I'm missing something.

So given the following asm snippet:

# cat snip.S
.if FOO == 1
.error "FOO"
.endif

Attempting to compile it with different compilers/assemblers:

# clang -o snip.o -c snip.S
snip.S:1:5: error: expected absolute expression
.if FOO == 1
    ^
snip.S:2:1: error: FOO
.error "FOO"
^
# gcc -o snip.o -c snip.S
# as -o snip.o snip.S

So there's clearly something different in how as/gcc handle .if
directives when they reference undefined symbols versus clang.

I can expand the commit message to reflect/include the above, but I
think the change still stands.

Thanks, Roger.

_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxxxxxxxxx
https://lists.xenproject.org/mailman/listinfo/xen-devel

 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.