From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 89498 invoked by alias); 2 Jun 2016 14:20:31 -0000 Mailing-List: contact gcc-patches-help@gcc.gnu.org; run by ezmlm Precedence: bulk List-Id: List-Archive: List-Post: List-Help: Sender: gcc-patches-owner@gcc.gnu.org Received: (qmail 89476 invoked by uid 89); 2 Jun 2016 14:20:30 -0000 Authentication-Results: sourceware.org; auth=none X-Virus-Found: No X-Spam-SWARE-Status: No, score=0.2 required=5.0 tests=BAYES_00,FREEMAIL_FROM,RCVD_IN_DNSWL_LOW,SPF_PASS,UNWANTED_LANGUAGE_BODY autolearn=ham version=3.3.2 spammy=i386.c, i386c, UD:i386.c X-HELO: mail-wm0-f47.google.com Received: from mail-wm0-f47.google.com (HELO mail-wm0-f47.google.com) (74.125.82.47) by sourceware.org (qpsmtpd/0.93/v0.84-503-g423c35a) with (AES128-GCM-SHA256 encrypted) ESMTPS; Thu, 02 Jun 2016 14:20:20 +0000 Received: by mail-wm0-f47.google.com with SMTP id a136so232744268wme.0 for ; Thu, 02 Jun 2016 07:20:19 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=3QyTR4KcFuy2Yigi0j6JgOhgtdk2fnLPBs/0KWourVs=; b=bLpSuXGiVLlhxura8UA7HBZLUGvt7Y18TVdWNWaPi3VhhwcDXvo/0Nlrihcq7/Jd3h cxQhgLdFKeOBKnlzzw0CzUKPzY+QvSAz2ERq7Tj6E+vqKovBj2GUN7wB8eEzbIaHwnm7 7LedfX0g7k4nhR/33ssRoXLR8/+etstOyFnHxjWfQEK3lfCvMn12BCZXIX0jIKiaU82e wavzj/UazdR9bLc3Awj6f8wKSPeLKdUKZq8FTfRc273Mz2sVp1XeO6Kwsu1rpCrTbNMg mn4asjxLD/iJM+lxqt4MSQz5fhG14ESi6Wab5ASnRyEqEfqGW1qmIUt10lb/RFrsfaNU 79RA== X-Gm-Message-State: ALyK8tLeUw7jMw+UZE2/1AlLFfb2DslLC8x4S6CzeHDF7JDb6gcDT7XvNCAJwJBTNjhSig== X-Received: by 10.28.3.70 with SMTP id 67mr8909619wmd.32.1464877217284; Thu, 02 Jun 2016 07:20:17 -0700 (PDT) Received: from msticlxl57.ims.intel.com (irdmzpr02-ext.ir.intel.com. [192.198.151.37]) by smtp.gmail.com with ESMTPSA id c191sm12014637wmh.5.2016.06.02.07.20.15 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 02 Jun 2016 07:20:16 -0700 (PDT) Date: Thu, 02 Jun 2016 14:20:00 -0000 From: Ilya Verbin To: Uros Bizjak , Kirill Yukhin , Jakub Jelinek , Richard Biener Cc: gcc-patches@gcc.gnu.org Subject: Re: [PATCH, i386, AVX-512] Add vectorizer support builtins Message-ID: <20160602141753.GA40481@msticlxl57.ims.intel.com> References: <20160523161153.GB65362@msticlxl57.ims.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20160523161153.GB65362@msticlxl57.ims.intel.com> User-Agent: Mutt/1.5.23 (2014-03-12) X-IsSubscribed: yes X-SW-Source: 2016-06/txt/msg00172.txt.bz2 On Mon, May 23, 2016 at 19:11:53 +0300, Ilya Verbin wrote: > This patch adds missed 512-bit rounding builtins for vectorization. > Regtested on x86_64-linux and i686-linux. OK for trunk? > > gcc/ > * config/i386/i386-builtin-types.def: Add V16SI_FTYPE_V16SF, > V8DF_FTYPE_V8DF_ROUND, V16SF_FTYPE_V16SF_ROUND, V16SI_FTYPE_V16SF_ROUND. > * config/i386/i386.c (enum ix86_builtins): Add > IX86_BUILTIN_CVTPS2DQ512_MASK, IX86_BUILTIN_FLOORPS512, > IX86_BUILTIN_FLOORPD512, IX86_BUILTIN_CEILPS512, IX86_BUILTIN_CEILPD512, > IX86_BUILTIN_TRUNCPS512, IX86_BUILTIN_TRUNCPD512, > IX86_BUILTIN_CVTPS2DQ512, IX86_BUILTIN_VEC_PACK_SFIX512, > IX86_BUILTIN_FLOORPS_SFIX512, IX86_BUILTIN_CEILPS_SFIX512, > IX86_BUILTIN_ROUNDPS_AZ_SFIX512. > (builtin_description bdesc_args): Add __builtin_ia32_floorps512, > __builtin_ia32_ceilps512, __builtin_ia32_truncps512, > __builtin_ia32_floorpd512, __builtin_ia32_ceilpd512, > __builtin_ia32_truncpd512, __builtin_ia32_cvtps2dq512, > __builtin_ia32_vec_pack_sfix512, __builtin_ia32_roundps_az_sfix512, > __builtin_ia32_floorps_sfix512, __builtin_ia32_ceilps_sfix512. > Change IX86_BUILTIN_CVTPS2DQ512 to IX86_BUILTIN_CVTPS2DQ512_MASK for > __builtin_ia32_cvtps2dq512_mask. > (ix86_expand_args_builtin): Handle V8DF_FTYPE_V8DF_ROUND, > V16SF_FTYPE_V16SF_ROUND, V16SI_FTYPE_V16SF_ROUND, V16SI_FTYPE_V16SF. > (ix86_builtin_vectorized_function): Handle builtins mentioned above. > * config/i386/sse.md > (avx512f_fix_notruncv16sfv16si): > Rename to ... > (avx512f_fix_notruncv16sfv16si): ... this. > (avx512f_cvtpd2dq512): Rename > to ... > (avx512f_cvtpd2dq512): ... this. > (avx512f_vec_pack_sfix_v8df): New define_expand. > (avx512f_roundpd512): Rename to ... > (avx512f_round512): ... this. Change iterator. > (avx512f_roundps512_sfix): New define_expand. > (round2_sfix): Change iterator. > gcc/testsuite/ > * gcc.target/i386/avx512f-ceil-vec-1.c: New test. > * gcc.target/i386/avx512f-ceil-vec-2.c: New test. > * gcc.target/i386/avx512f-ceilf-sfix-vec-1.c: New test. > * gcc.target/i386/avx512f-ceilf-sfix-vec-2.c: New test. > * gcc.target/i386/avx512f-ceilf-vec-1.c: New test. > * gcc.target/i386/avx512f-ceilf-vec-2.c: New test. > * gcc.target/i386/avx512f-floor-vec-1.c: New test. > * gcc.target/i386/avx512f-floor-vec-2.c: New test. > * gcc.target/i386/avx512f-floorf-sfix-vec-1.c: New test. > * gcc.target/i386/avx512f-floorf-sfix-vec-2.c: New test. > * gcc.target/i386/avx512f-floorf-vec-1.c: New test. > * gcc.target/i386/avx512f-floorf-vec-2.c: New test. > * gcc.target/i386/avx512f-rint-sfix-vec-1.c: New test. > * gcc.target/i386/avx512f-rint-sfix-vec-2.c: New test. > * gcc.target/i386/avx512f-rintf-sfix-vec-1.c: New test. > * gcc.target/i386/avx512f-rintf-sfix-vec-2.c: New test. > * gcc.target/i386/avx512f-round-sfix-vec-1.c: New test. > * gcc.target/i386/avx512f-round-sfix-vec-2.c: New test. > * gcc.target/i386/avx512f-roundf-sfix-vec-1.c: New test. > * gcc.target/i386/avx512f-roundf-sfix-vec-2.c: New test. > * gcc.target/i386/avx512f-trunc-vec-1.c: New test. > * gcc.target/i386/avx512f-trunc-vec-2.c: New test. > * gcc.target/i386/avx512f-truncf-vec-1.c: New test. > * gcc.target/i386/avx512f-truncf-vec-2.c: New test. Is it OK for gcc-6-branch? -- Ilya