swapgs
        FRAME_END
        RET
-SYM_FUNC_END(asm_load_gs_index)
-EXPORT_SYMBOL(asm_load_gs_index)
 
-       _ASM_EXTABLE(.Lgs_change, .Lbad_gs)
-       .section .fixup, "ax"
        /* running with kernelgs */
-SYM_CODE_START_LOCAL_NOALIGN(.Lbad_gs)
+.Lbad_gs:
        swapgs                                  /* switch back to user gs */
 .macro ZAP_GS
        /* This can't be a string because the preprocessor needs to see it. */
        xorl    %eax, %eax
        movl    %eax, %gs
        jmp     2b
-SYM_CODE_END(.Lbad_gs)
-       .previous
+
+       _ASM_EXTABLE(.Lgs_change, .Lbad_gs)
+
+SYM_FUNC_END(asm_load_gs_index)
+EXPORT_SYMBOL(asm_load_gs_index)
 
 #ifdef CONFIG_XEN_PV
 /*