From: Olivier Hainque Date: Tue, 5 Jan 2016 18:10:31 +0000 (+0000) Subject: aix-unwind.h (ucontext_for): Handle AIX 7.1 specificities. X-Git-Tag: basepoints/gcc-7~1818 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=a22189835a1f1f775263c8bc4d015d9a98b3a212;p=thirdparty%2Fgcc.git aix-unwind.h (ucontext_for): Handle AIX 7.1 specificities. 2016-01-05 Olivier Hainque * config/rs6000/aix-unwind.h (ucontext_for): Handle AIX 7.1 specificities. From-SVN: r232082 --- diff --git a/libgcc/ChangeLog b/libgcc/ChangeLog index 484c7268c6a5..4a9b5d39b856 100644 --- a/libgcc/ChangeLog +++ b/libgcc/ChangeLog @@ -1,3 +1,8 @@ +2016-01-05 Olivier Hainque + + * config/rs6000/aix-unwind.h (ucontext_for): Handle AIX 7.1 + specificities. + 2016-01-04 Jakub Jelinek Update copyright years. diff --git a/libgcc/config/rs6000/aix-unwind.h b/libgcc/config/rs6000/aix-unwind.h index 16a1a9e1dc01..4edeaf4606be 100644 --- a/libgcc/config/rs6000/aix-unwind.h +++ b/libgcc/config/rs6000/aix-unwind.h @@ -64,7 +64,7 @@ #endif /* Now on to MD_FALLBACK_FRAME_STATE_FOR. - 32bit AIX 5.2 and 5.3 only at this stage. */ + 32bit AIX 5.2, 5.3 and 7.1 only at this stage. */ #include #include @@ -128,8 +128,9 @@ ucontext_for (struct _Unwind_Context *context) { const unsigned int * ra = context->ra; - /* AIX 5.2 and 5.3, threaded or not, share common patterns and feature - variants depending on the configured kernel (unix_mp or unix_64). */ + /* AIX 5.2, 5.3 and 7.1, threaded or not, share common patterns + and feature variants depending on the configured kernel (unix_mp + or unix_64). */ if (*(ra - 5) == 0x4c00012c /* isync */ && *(ra - 4) == 0x80ec0000 /* lwz r7,0(r12) */ @@ -150,6 +151,10 @@ ucontext_for (struct _Unwind_Context *context) /* AIX 5.3 */ case 0x835a0570: /* lwz r26,1392(r26) */ return (ucontext_t *)(context->cfa + 0x40); + + /* AIX 7.1 */ + case 0x2c1a0000: /* cmpwi r26,0 */ + return (ucontext_t *)(context->cfa + 0x40); default: return 0;