annotate gcc/testsuite/gcc.dg/attr-access-read-only.c @ 145:1830386684a0

gcc-9.2.0
author anatofuz
date Thu, 13 Feb 2020 11:34:05 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
145
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
1 /* PR middle-end/83859 - attribute to establish relation between parameters
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
2 for buffer and its size
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
3 Test to verify the handling of attribute access (read_only) syntax.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
4 { dg-do compile }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
5 { dg-options "-Wall -ftrack-macro-expansion=0" } */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
6
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
7 int __attribute__ ((access))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
8 access_v (void); // { dg-error "wrong number of arguments specified for 'access' attribute" }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
9
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
10 int __attribute__ ((access ()))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
11 access___v (void); // { dg-error "wrong number of arguments specified for 'access' attribute" }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
12
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
13 int __attribute__ ((access (rdonly)))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
14 rdonly_spelling (void); // { dg-error "attribute .access. invalid mode 'rdonly'; expected one of 'read_only', 'read_write', or 'write_only'" }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
15
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
16 int __attribute__ ((access (read_only)))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
17 rdonly_v_all (void); // { dg-error "attribute .access\\(read_only\\). missing an argument" }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
18
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
19 int __attribute__ ((access (read_only ())))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
20 rdonly___v_all (void); // { dg-error "attribute 'access' unexpected '\\(' after mode 'read_only'; expected a positional argument or '\\)'" }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
21 // { dg-warning "implicit declaration of function 'read_only'" "" { target *-*-* } .-2 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
22
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
23
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
24 int rdonly (void);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
25
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
26 int __attribute__ ((access (rdonly ())))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
27 rdonly___v_all (void); // { dg-error "attribute 'access' invalid mode 'rdonly'" }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
28
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
29
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
30 int __attribute__ ((access (read_only)))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
31 rdonly_i_all (int); // { dg-error "attribute .access\\(read_only\\). missing an argument" }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
32
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
33 #define rdonly __attribute__ ((access (read_only)))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
34 #define RDONLY(...) __attribute__ ((access (read_only, __VA_ARGS__)))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
35
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
36 int RDONLY (1)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
37 rdonly_pcv_1 (const void*);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
38 int RDONLY (2)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
39 rdonly_i_pcv_2 (int, const void*);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
40 int RDONLY (3)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
41 rdonly_i_i_pcv_3 (int, int, const void*);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
42
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
43 int RDONLY (0 + 1)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
44 rdonly_pcv_0p1 (const void*);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
45
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
46 int RDONLY (2 - 1)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
47 rdonly_pcv_2m1 (const void*);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
48
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
49 int RDONLY (1, 1)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
50 rdonly_pv_pi_1_1 (const void*, const int*); // { dg-error "attribute 'access\\(read_only, 1, 1\\)' positional argument 2 references non-integer argument type 'const void \\*'" }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
51
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
52 int RDONLY (1, 2)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
53 rdonly_pcv_pc_1_2 (const void*, char*); // { dg-error "attribute .access\\(read_only, 1, 2\\)' positional argument 2 references non-integer argument type 'char \\*'" }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
54
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
55 int RDONLY (2, 1)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
56 rdonly_pcd_pcv_2_1 (const double*, const void*); // { dg-error "attribute .access\\(read_only, 2, 1\\)' positional argument 2 references non-integer argument type 'const double \\*'" }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
57
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
58 int RDONLY (2, 2)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
59 rdonly_pi_pcv_2_2 (int*, const void*); // { dg-error "positional argument 2 references non-integer argument type 'const void \\*'" }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
60
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
61 int RDONLY (4)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
62 rdonly_i_i_i_4 (int, int, int); // { dg-error "attribute 'access\\(read_only, 4\\)' positional argument 1 value 4 exceeds number of function arguments 3" }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
63
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
64 int RDONLY (1)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
65 rdonly_i_1 (int); // { dg-error "attribute 'access\\(read_only, 1\\)' positional argument 1 references non-pointer argument type 'int'" }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
66
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
67 // It's okay if the pointer argument is non-const, although a separate
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
68 // warning encouraging one might be worthwhile. Maybe something like
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
69 // -Wsuggest-const.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
70 int RDONLY (2)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
71 rdonly_i_pc (int, char*);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
72
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
73 int RDONLY (-1)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
74 rdonly_pcv_m1 (const void*); // { dg-error "attribute 'access\\(read_only, -1\\)' positional argument 1 invalid value -1" }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
75
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
76 int RDONLY (1, -12345)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
77 rdonly_pcv_i_1_m12345 (const void*, int*); // { dg-error "attribute 'access\\(read_only, 1, -12345\\)' positional argument 2 invalid value -12345" }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
78
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
79 int RDONLY ("blah")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
80 rdonly_pcv_str (const void*); // { dg-error "attribute 'access\\(read_only, \"blah\"\\)' invalid positional argument 1" }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
81
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
82 int RDONLY (1, "foobar")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
83 rdonly_pcv_i_1_str (const void*, int); // { dg-error "attribute 'access\\(read_only, 1, \"foobar\"\\)' invalid positional argument 2" }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
84
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
85 // Verify that attributes whose operands reference function pointers
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
86 // are rejected.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
87 typedef int F (int, int);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
88 RDONLY (1) void rdwr_pf_1 (F*); // { dg-error "attribute 'access\\(read_only, 1\\)' positional argument 1 references argument of function type 'F' \\{aka 'int\\(int, *int\\)'\\}" }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
89
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
90 // Verify pointers to functions.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
91 void RDONLY(2) (*prdonly_pcv2)(int, const void*);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
92 void RDONLY(3, 1) (*prdonly_pcv2_1)(int, void*, const void*);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
93
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
94 // Verify types.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
95 typedef RDONLY (2) void rdonly_p2_t (const int*, const char*, const void*);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
96 typedef RDONLY (2) void rdonly_p2_1 (int, const int*);