From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 11477 invoked by alias); 9 Jan 2015 17:57:07 -0000 Mailing-List: contact gcc-bugs-help@gcc.gnu.org; run by ezmlm Precedence: bulk List-Id: List-Archive: List-Post: List-Help: Sender: gcc-bugs-owner@gcc.gnu.org Received: (qmail 11351 invoked by uid 48); 9 Jan 2015 17:57:02 -0000 From: "jakub at gcc dot gnu.org" To: gcc-bugs@gcc.gnu.org Subject: [Bug rtl-optimization/64286] Redundant extend removal ignores vector element type Date: Fri, 09 Jan 2015 17:57:00 -0000 X-Bugzilla-Reason: CC X-Bugzilla-Type: changed X-Bugzilla-Watch-Reason: None X-Bugzilla-Product: gcc X-Bugzilla-Component: rtl-optimization X-Bugzilla-Version: 4.9.0 X-Bugzilla-Keywords: wrong-code X-Bugzilla-Severity: major X-Bugzilla-Who: jakub at gcc dot gnu.org X-Bugzilla-Status: NEW X-Bugzilla-Priority: P3 X-Bugzilla-Assigned-To: unassigned at gcc dot gnu.org X-Bugzilla-Target-Milestone: --- X-Bugzilla-Flags: X-Bugzilla-Changed-Fields: bug_status cf_reconfirmed_on everconfirmed Message-ID: In-Reply-To: References: Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit X-Bugzilla-URL: http://gcc.gnu.org/bugzilla/ Auto-Submitted: auto-generated MIME-Version: 1.0 X-SW-Source: 2015-01/txt/msg00641.txt.bz2 https://gcc.gnu.org/bugzilla/show_bug.cgi?id=64286 Jakub Jelinek changed: What |Removed |Added ---------------------------------------------------------------------------- Status|UNCONFIRMED |NEW Last reconfirmed| |2015-01-09 Ever confirmed|0 |1 --- Comment #5 from Jakub Jelinek --- Reduced testcase (-O2 -mavx2): #include #include #include __m128i v; __m256i w; __attribute__((noinline, noclone)) void foo (__m128i *p, __m128i *q) { __m128i a = _mm_loadu_si128 (p); __m128i b = _mm_xor_si128 (a, v); w = _mm256_cvtepu8_epi16 (a); *q = b; } int main () { v = _mm_set1_epi8 (0x40); __m128i c = _mm_set_epi8 (16, 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1); __m128i d; foo (&c, &d); __m128i e = _mm_set_epi8 (0x50, 0x4f, 0x4e, 0x4d, 0x4c, 0x4b, 0x4a, 0x49, 0x48, 0x47, 0x46, 0x45, 0x44, 0x43, 0x42, 0x41); __m256i f = _mm256_set_epi16 (16, 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1); if (memcmp (&w, &f, sizeof (w)) != 0 || memcmp (&d, &e, sizeof (d)) != 0) abort (); return 0; }