struct / union in initializer, RFE #901.
[sdcc.git] / sdcc / support / regression / tests / mm-pnvi-ae-udi-pointer_copy_user_ctrlflow_bitwise.c
blobf140726ed457ac5bee8dd036b71aaada537861a5
1 // Derived from test case from the memory model study group of SC22 WG14
2 // For this test, behaviour is defined in the PNVI-ae-udi memory model.
4 /*
5 Original test copyright (c) 2012-2016 David Chisnall, Kayvan Memarian, and Peter Sewell.
7 Permission to use, copy, modify, and/or distribute this software for
8 any purpose with or without fee is hereby granted, provided that the
9 above copyright notice and this permission notice appear in all
10 copies.
12 THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
13 WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
14 WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
15 AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
16 DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
17 PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
18 TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
19 PERFORMANCE OF THIS SOFTWARE.
22 // Adapted for SDCC by Philipp Klaus Krause in 2020.
24 #include <testfwk.h>
26 #pragma disable_warning 127
28 #include <stdint.h>
29 #include <limits.h>
31 int x=1;
33 void
34 testMM(void)
36 int *p = &x;
37 uintptr_t i = (uintptr_t)p;
38 int uintptr_t_width = sizeof(uintptr_t) * CHAR_BIT;
39 uintptr_t bit, j;
40 int k;
41 j=0;
42 for (k=0; k<uintptr_t_width; k++) {
43 bit = (i & (((uintptr_t)1) << k)) >> k;
44 if (bit == 1)
45 j = j | ((uintptr_t)1 << k);
46 else
47 j = j;
49 int *q = (int *)j;
50 *q = 11; // is this free of undefined behaviour?
51 ASSERT (*p == *q);