This patch adds tests for using the PC-relative addressing on the 'future' system.
Can I check this patch into the FSF trunk after the patch in the V7 series that enables PC-relative addressing by default on 64-bit Linux systems has been commited? 2019-11-14 Michael Meissner <meiss...@linux.ibm.com> * gcc/testsuite/gcc.target/powerpc/prefix-pcrel.h: New set of tests to test prefixed addressing on 'future' system with PC-relative tests. * gcc/testsuite/gcc.target/powerpc/prefix-pcrel-dd.c: New test. * gcc/testsuite/gcc.target/powerpc/prefix-pcrel-df.c: New test. * gcc/testsuite/gcc.target/powerpc/prefix-pcrel-di.c: New test. * gcc/testsuite/gcc.target/powerpc/prefix-pcrel-hi.c: New test. * gcc/testsuite/gcc.target/powerpc/prefix-pcrel-kf.c: New test. * gcc/testsuite/gcc.target/powerpc/prefix-pcrel-qi.c: New test. * gcc/testsuite/gcc.target/powerpc/prefix-pcrel-sd.c: New test. * gcc/testsuite/gcc.target/powerpc/prefix-pcrel-sf.c: New test. * gcc/testsuite/gcc.target/powerpc/prefix-pcrel-si.c: New test. * gcc/testsuite/gcc.target/powerpc/prefix-pcrel-udi.c: New test. * gcc/testsuite/gcc.target/powerpc/prefix-pcrel-uhi.c: New test. * gcc/testsuite/gcc.target/powerpc/prefix-pcrel-uqi.c: New test. * gcc/testsuite/gcc.target/powerpc/prefix-pcrel-usi.c: New test. * gcc/testsuite/gcc.target/powerpc/prefix-pcrel-v2df.c: New test. --- /tmp/79Y8V6_prefix-pcrel-dd.c 2019-11-13 17:43:34.462087329 -0500 +++ gcc/testsuite/gcc.target/powerpc/prefix-pcrel-dd.c 2019-11-13 17:43:34.183084816 -0500 @@ -0,0 +1,13 @@ +/* { dg-do compile } */ +/* { dg-require-effective-target powerpc_pcrel_ok } */ +/* { dg-options "-O2 -mdejagnu-cpu=future" } */ + +/* Tests for prefixed instructions testing whether pc-relative prefixed + instructions are generated for SImode. */ + +#define TYPE _Decimal64 + +#include "prefix-pcrel.h" + +/* { dg-final { scan-assembler-times {\mplfd\M} 2 } } */ +/* { dg-final { scan-assembler-times {\mpstfd\M} 2 } } */ --- /tmp/st8ftv_prefix-pcrel-df.c 2019-11-13 17:43:34.472087419 -0500 +++ gcc/testsuite/gcc.target/powerpc/prefix-pcrel-df.c 2019-11-13 17:43:34.188084861 -0500 @@ -0,0 +1,13 @@ +/* { dg-do compile } */ +/* { dg-require-effective-target powerpc_pcrel_ok } */ +/* { dg-options "-O2 -mdejagnu-cpu=future" } */ + +/* Tests for prefixed instructions testing whether pc-relative prefixed + instructions are generated for DFmode. */ + +#define TYPE double + +#include "prefix-pcrel.h" + +/* { dg-final { scan-assembler-times {\mplfd\M} 2 } } */ +/* { dg-final { scan-assembler-times {\mpstfd\M} 2 } } */ --- /tmp/Wo2P1T_prefix-pcrel-di.c 2019-11-13 17:43:34.479087482 -0500 +++ gcc/testsuite/gcc.target/powerpc/prefix-pcrel-di.c 2019-11-13 17:43:34.194084915 -0500 @@ -0,0 +1,13 @@ +/* { dg-do compile } */ +/* { dg-require-effective-target powerpc_pcrel_ok } */ +/* { dg-options "-O2 -mdejagnu-cpu=future" } */ + +/* Tests for prefixed instructions testing whether pc-relative prefixed + instructions are generated for DImode. */ + +#define TYPE long + +#include "prefix-pcrel.h" + +/* { dg-final { scan-assembler-times {\mpld\M} 2 } } */ +/* { dg-final { scan-assembler-times {\mpstd\M} 2 } } */ --- /tmp/KmOSBi_prefix-pcrel-hi.c 2019-11-13 17:43:34.487087554 -0500 +++ gcc/testsuite/gcc.target/powerpc/prefix-pcrel-hi.c 2019-11-13 17:43:34.199084960 -0500 @@ -0,0 +1,13 @@ +/* { dg-do compile } */ +/* { dg-require-effective-target powerpc_pcrel_ok } */ +/* { dg-options "-O2 -mdejagnu-cpu=future" } */ + +/* Tests for prefixed instructions testing whether pc-relative prefixed + instructions are generated for HImode. */ + +#define TYPE short + +#include "prefix-pcrel.h" + +/* { dg-final { scan-assembler-times {\mplh[az]\M} 2 } } */ +/* { dg-final { scan-assembler-times {\mpsth\M} 2 } } */ --- /tmp/BalpdH_prefix-pcrel-kf.c 2019-11-13 17:43:34.494087617 -0500 +++ gcc/testsuite/gcc.target/powerpc/prefix-pcrel-kf.c 2019-11-13 17:43:34.205085014 -0500 @@ -0,0 +1,13 @@ +/* { dg-do compile } */ +/* { dg-require-effective-target powerpc_pcrel_ok } */ +/* { dg-options "-O2 -mdejagnu-cpu=future" } */ + +/* Tests for prefixed instructions testing whether pc-relative prefixed + instructions are generated for KFmode. */ + +#define TYPE __float128 + +#include "prefix-pcrel.h" + +/* { dg-final { scan-assembler-times {\mplxv\M} 2 } } */ +/* { dg-final { scan-assembler-times {\mpstxv\M} 2 } } */ --- /tmp/FMdpQ5_prefix-pcrel-qi.c 2019-11-13 17:43:34.502087689 -0500 +++ gcc/testsuite/gcc.target/powerpc/prefix-pcrel-qi.c 2019-11-13 17:43:34.210085059 -0500 @@ -0,0 +1,13 @@ +/* { dg-do compile } */ +/* { dg-require-effective-target powerpc_pcrel_ok } */ +/* { dg-options "-O2 -mdejagnu-cpu=future" } */ + +/* Tests for prefixed instructions testing whether pc-relative prefixed + instructions are generated for QImode. */ + +#define TYPE signed char + +#include "prefix-pcrel.h" + +/* { dg-final { scan-assembler-times {\mplbz\M} 2 } } */ +/* { dg-final { scan-assembler-times {\mpstb\M} 2 } } */ --- /tmp/74AMuu_prefix-pcrel-sd.c 2019-11-13 17:43:34.509087752 -0500 +++ gcc/testsuite/gcc.target/powerpc/prefix-pcrel-sd.c 2019-11-13 17:43:34.215085104 -0500 @@ -0,0 +1,12 @@ +/* { dg-do compile } */ +/* { dg-require-effective-target powerpc_pcrel_ok } */ +/* { dg-options "-O2 -mdejagnu-cpu=future" } */ + +/* Tests for prefixed instructions testing whether pc-relative prefixed + instructions are generated for SImode. */ + +#define TYPE _Decimal32 + +#include "prefix-pcrel.h" + +/* { dg-final { scan-assembler-times {\mpaddi|\mpla\M} 3 } } */ --- /tmp/yelAaT_prefix-pcrel-sf.c 2019-11-13 17:43:34.516087815 -0500 +++ gcc/testsuite/gcc.target/powerpc/prefix-pcrel-sf.c 2019-11-13 17:43:34.220085149 -0500 @@ -0,0 +1,13 @@ +/* { dg-do compile } */ +/* { dg-require-effective-target powerpc_pcrel_ok } */ +/* { dg-options "-O2 -mdejagnu-cpu=future" } */ + +/* Tests for prefixed instructions testing whether pc-relative prefixed + instructions are generated for SFmode. */ + +#define TYPE float + +#include "prefix-pcrel.h" + +/* { dg-final { scan-assembler-times {\mplfs\M} 2 } } */ +/* { dg-final { scan-assembler-times {\mpstfs\M} 2 } } */ --- /tmp/mEYMRh_prefix-pcrel-si.c 2019-11-13 17:43:34.523087878 -0500 +++ gcc/testsuite/gcc.target/powerpc/prefix-pcrel-si.c 2019-11-13 17:43:34.226085203 -0500 @@ -0,0 +1,13 @@ +/* { dg-do compile } */ +/* { dg-require-effective-target powerpc_pcrel_ok } */ +/* { dg-options "-O2 -mdejagnu-cpu=future" } */ + +/* Tests for prefixed instructions testing whether pc-relative prefixed + instructions are generated for SImode. */ + +#define TYPE int + +#include "prefix-pcrel.h" + +/* { dg-final { scan-assembler-times {\mplw[az]\M} 2 } } */ +/* { dg-final { scan-assembler-times {\mpstw\M} 2 } } */ --- /tmp/yqapAG_prefix-pcrel-udi.c 2019-11-13 17:43:34.530087941 -0500 +++ gcc/testsuite/gcc.target/powerpc/prefix-pcrel-udi.c 2019-11-13 17:43:34.231085248 -0500 @@ -0,0 +1,13 @@ +/* { dg-do compile } */ +/* { dg-require-effective-target powerpc_pcrel_ok } */ +/* { dg-options "-O2 -mdejagnu-cpu=future" } */ + +/* Tests for prefixed instructions testing whether pc-relative prefixed + instructions are generated for unsigned DImode. */ + +#define TYPE unsigned long + +#include "prefix-pcrel.h" + +/* { dg-final { scan-assembler-times {\mpld\M} 2 } } */ +/* { dg-final { scan-assembler-times {\mpstd\M} 2 } } */ --- /tmp/CbOmk5_prefix-pcrel-uhi.c 2019-11-13 17:43:34.537088004 -0500 +++ gcc/testsuite/gcc.target/powerpc/prefix-pcrel-uhi.c 2019-11-13 17:43:34.237085302 -0500 @@ -0,0 +1,13 @@ +/* { dg-do compile } */ +/* { dg-require-effective-target powerpc_pcrel_ok } */ +/* { dg-options "-O2 -mdejagnu-cpu=future" } */ + +/* Tests for prefixed instructions testing whether pc-relative prefixed + instructions are generated for unsigned HImode. */ + +#define TYPE unsigned short + +#include "prefix-pcrel.h" + +/* { dg-final { scan-assembler-times {\mplhz\M} 2 } } */ +/* { dg-final { scan-assembler-times {\mpsth\M} 2 } } */ --- /tmp/fNaH5t_prefix-pcrel-uqi.c 2019-11-13 17:43:34.544088067 -0500 +++ gcc/testsuite/gcc.target/powerpc/prefix-pcrel-uqi.c 2019-11-13 17:43:34.242085347 -0500 @@ -0,0 +1,13 @@ +/* { dg-do compile } */ +/* { dg-require-effective-target powerpc_pcrel_ok } */ +/* { dg-options "-O2 -mdejagnu-cpu=future" } */ + +/* Tests for prefixed instructions testing whether pc-relative prefixed + instructions are generated for unsigned QImode. */ + +#define TYPE unsigned char + +#include "prefix-pcrel.h" + +/* { dg-final { scan-assembler-times {\mplbz\M} 2 } } */ +/* { dg-final { scan-assembler-times {\mpstb\M} 2 } } */ --- /tmp/RLqlSS_prefix-pcrel-usi.c 2019-11-13 17:43:34.551088130 -0500 +++ gcc/testsuite/gcc.target/powerpc/prefix-pcrel-usi.c 2019-11-13 17:43:34.248085401 -0500 @@ -0,0 +1,13 @@ +/* { dg-do compile } */ +/* { dg-require-effective-target powerpc_pcrel_ok } */ +/* { dg-options "-O2 -mdejagnu-cpu=future" } */ + +/* Tests for prefixed instructions testing whether pc-relative prefixed + instructions are generated for unsigned SImode. */ + +#define TYPE unsigned int + +#include "prefix-pcrel.h" + +/* { dg-final { scan-assembler-times {\mplwz\M} 2 } } */ +/* { dg-final { scan-assembler-times {\mpstw\M} 2 } } */ --- /tmp/aIknGh_prefix-pcrel-v2df.c 2019-11-13 17:43:34.558088193 -0500 +++ gcc/testsuite/gcc.target/powerpc/prefix-pcrel-v2df.c 2019-11-13 17:43:34.253085446 -0500 @@ -0,0 +1,13 @@ +/* { dg-do compile } */ +/* { dg-require-effective-target powerpc_pcrel_ok } */ +/* { dg-options "-O2 -mdejagnu-cpu=future" } */ + +/* Tests for prefixed instructions testing whether pc-relative prefixed + instructions are generated for V2DFmode. */ + +#define TYPE vector double + +#include "prefix-pcrel.h" + +/* { dg-final { scan-assembler-times {\mplxv\M} 2 } } */ +/* { dg-final { scan-assembler-times {\mpstxv\M} 2 } } */ --- /tmp/l1IJvG_prefix-pcrel.h 2019-11-13 17:43:34.565088256 -0500 +++ gcc/testsuite/gcc.target/powerpc/prefix-pcrel.h 2019-11-13 17:43:34.258085492 -0500 @@ -0,0 +1,58 @@ +/* Common tests for prefixed instructions testing whether pc-relative prefixed + instructions are generated for each type. */ + +typedef signed char schar; +typedef unsigned char uchar; +typedef unsigned short ushort; +typedef unsigned int uint; +typedef unsigned long ulong; +typedef long double ldouble; +typedef vector double v2df; +typedef vector long v2di; +typedef vector float v4sf; +typedef vector int v4si; + +#ifndef TYPE +#define TYPE ulong +#endif + +#ifndef ITYPE +#define ITYPE TYPE +#endif + +#ifndef OTYPE +#define OTYPE TYPE +#endif + +static TYPE a; +TYPE *p = &a; + +#if !defined(DO_ADD) && !defined(DO_VALUE) && !defined(DO_SET) +#define DO_ADD 1 +#define DO_VALUE 1 +#define DO_SET 1 +#endif + +#if DO_ADD +void +add (TYPE b) +{ + a += b; +} +#endif + +#if DO_VALUE +OTYPE +value (void) +{ + return (OTYPE)a; +} +#endif + +#if DO_SET +void +set (ITYPE b) +{ + a = (TYPE)b; +} +#endif -- Michael Meissner, IBM IBM, M/S 2506R, 550 King Street, Littleton, MA 01460-6245, USA email: meiss...@linux.ibm.com, phone: +1 (978) 899-4797