static inline int plo_test_bit(unsigned char nr)
 {
-       register unsigned long r0 asm("0") = (unsigned long) nr | 0x100;
+       unsigned long function = (unsigned long)nr | 0x100;
        int cc;
 
        asm volatile(
+               "       lgr     0,%[function]\n"
                /* Parameter registers are ignored for "test bit" */
                "       plo     0,0,0,0(0)\n"
                "       ipm     %0\n"
                "       srl     %0,28\n"
                : "=d" (cc)
-               : "d" (r0)
-               : "cc");
+               : [function] "d" (function)
+               : "cc", "0");
        return cc == 0;
 }
 
 static __always_inline void __insn32_query(unsigned int opcode, u8 *query)
 {
-       register unsigned long r0 asm("0") = 0; /* query function */
-       register unsigned long r1 asm("1") = (unsigned long) query;
-
        asm volatile(
-               /* Parameter regs are ignored */
+               "       lghi    0,0\n"
+               "       lgr     1,%[query]\n"
+               /* Parameter registers are ignored */
                "       .insn   rrf,%[opc] << 16,2,4,6,0\n"
                :
-               : "d" (r0), "a" (r1), [opc] "i" (opcode)
-               : "cc", "memory");
+               : [query] "d" ((unsigned long)query), [opc] "i" (opcode)
+               : "cc", "memory", "0", "1");
 }
 
 #define INSN_SORTL 0xb938