IBM Support

LI76120: INVALID 'ADDI' INSTRUCTION SYNTAX

Subscribe

You can track all active APARs for this component.

 

APAR status

  • Closed as program error.

Error description

  • Source that makes use of inline assembly is hitting an error in
    the assembler due to invalid instruction syntax.
    
    
       === TEST CASE ===
    
    extern __thread int x, *p;
    
    void  mytest(void **fp)
    {
      __asm ("ori %0, 1, 0" : "=r" (*(&fp)));
      p = &x;
    }
    
    
    $ xlc -q64 -qtls -c tls.c
    Assembler:
    tls.s: line 76: Too few arguments
    1500-067: (S) asm statement generates errors in
       assembler output.
    
    
    The problem instruction generated in the *.s assembly file is:
    
       +76          addi      r0,0(r4)
    
    The parentheses syntax is invalid.  It should instead use a ','.
    

Local fix

  • N/A
    

Problem summary

  • PROBLEM DESCRIPTION:
    Assembly output from the compiler is using incorrect operand
    syntax.
    
    USERS AFFECTED:
    Those compiling source code that contains inline assembly and
    thread local storage, and are outputting to assembly code.
    

Problem conclusion

  • An issue was corrected with the syntax type the compiler uses
    to output to assembly code.  The problem is now fixed.
    

Temporary fix

Comments

APAR Information

  • APAR number

    LI76120

  • Reported component name

    XL C/C++ FOR LI

  • Reported component ID

    5724X1400

  • Reported release

    B10

  • Status

    CLOSED PER

  • PE

    NoPE

  • HIPER

    NoHIPER

  • Special Attention

    NoSpecatt / Xsystem

  • Submitted date

    2011-04-27

  • Closed date

    2011-04-27

  • Last modified date

    2011-04-27

  • APAR is sysrouted FROM one or more of the following:

    IZ92278

  • APAR is sysrouted TO one or more of the following:

Fix information

  • Fixed component name

    XL C/C++ FOR LI

  • Fixed component ID

    5724X1400

Applicable component levels

[{"Business Unit":{"code":"BU058","label":"IBM Infrastructure w\/TPS"},"Product":{"code":"SSXVZZ","label":"XL C\/C++ for Linux"},"Platform":[{"code":"PF025","label":"Platform Independent"}],"Version":"B10","Line of Business":{"code":"LOB57","label":"Power"}}]

Document Information

Modified date:
17 October 2021