8
8
//!
9
9
//! Contains only the primitive types, mod.rs contains additional types
10
10
11
+ #![ stable( feature = "core_ffi" , since = "1.30.0" ) ]
12
+
11
13
type_alias ! { "c_char.md" , c_char = c_char_definition:: c_char; #[ doc( cfg( all( ) ) ) ] }
12
14
13
15
type_alias ! { "c_schar.md" , c_schar = i8 ; }
@@ -48,99 +50,6 @@ pub type c_ptrdiff_t = isize;
48
50
#[ unstable( feature = "c_size_t" , issue = "88345" ) ]
49
51
pub type c_ssize_t = isize ;
50
52
51
- mod c_char_definition {
52
- cfg_if ! {
53
- // These are the targets on which c_char is unsigned. Usually the
54
- // signedness is the same for all target_os values on a given architecture
55
- // but there are some exceptions (see isSignedCharDefault() in clang).
56
- //
57
- // aarch64:
58
- // Section 10 "Arm C and C++ language mappings" in Procedure Call Standard for the Arm®
59
- // 64-bit Architecture (AArch64) says C/C++ char is unsigned byte.
60
- // https://github.com/ARM-software/abi-aa/blob/2024Q3/aapcs64/aapcs64.rst#arm-c-and-c-language-mappings
61
- // arm:
62
- // Section 8 "Arm C and C++ Language Mappings" in Procedure Call Standard for the Arm®
63
- // Architecture says C/C++ char is unsigned byte.
64
- // https://github.com/ARM-software/abi-aa/blob/2024Q3/aapcs32/aapcs32.rst#arm-c-and-c-language-mappings
65
- // csky:
66
- // Section 2.1.2 "Primary Data Type" in C-SKY V2 CPU Applications Binary Interface
67
- // Standards Manual says ANSI C char is unsigned byte.
68
- // https://github.com/c-sky/csky-doc/blob/9f7121f7d40970ba5cc0f15716da033db2bb9d07/C-SKY_V2_CPU_Applications_Binary_Interface_Standards_Manual.pdf
69
- // Note: this doesn't seem to match Clang's default (https://github.com/rust-lang/rust/issues/129945).
70
- // hexagon:
71
- // Section 3.1 "Basic data type" in Qualcomm Hexagon™ Application
72
- // Binary Interface User Guide says "By default, the `char` data type is unsigned."
73
- // https://docs.qualcomm.com/bundle/publicresource/80-N2040-23_REV_K_Qualcomm_Hexagon_Application_Binary_Interface_User_Guide.pdf
74
- // msp430:
75
- // Section 2.1 "Basic Types" in MSP430 Embedded Application Binary
76
- // Interface says "The char type is unsigned by default".
77
- // https://www.ti.com/lit/an/slaa534a/slaa534a.pdf
78
- // powerpc/powerpc64:
79
- // - PPC32 SysV: "Table 3-1 Scalar Types" in System V Application Binary Interface PowerPC
80
- // Processor Supplement says ANSI C char is unsigned byte
81
- // https://refspecs.linuxfoundation.org/elf/elfspec_ppc.pdf
82
- // - PPC64 ELFv1: Section 3.1.4 "Fundamental Types" in 64-bit PowerPC ELF Application
83
- // Binary Interface Supplement 1.9 says ANSI C is unsigned byte
84
- // https://refspecs.linuxfoundation.org/ELF/ppc64/PPC-elf64abi.html#FUND-TYPE
85
- // - PPC64 ELFv2: Section 2.1.2.2 "Fundamental Types" in 64-Bit ELF V2 ABI Specification
86
- // says char is unsigned byte
87
- // https://openpowerfoundation.org/specifications/64bitelfabi/
88
- // - AIX: XL C for AIX Language Reference says "By default, char behaves like an unsigned char."
89
- // https://www.ibm.com/docs/en/xl-c-aix/13.1.3?topic=specifiers-character-types
90
- // riscv32/riscv64:
91
- // C/C++ type representations section in RISC-V Calling Conventions
92
- // page in RISC-V ELF psABI Document says "char is unsigned."
93
- // https://github.com/riscv-non-isa/riscv-elf-psabi-doc/blob/draft-20240829-13bfa9f54634cb60d86b9b333e109f077805b4b3/riscv-cc.adoc#cc-type-representations
94
- // s390x:
95
- // - ELF: "Table 1.1.: Scalar types" in ELF Application Binary Interface s390x Supplement
96
- // Version 1.6.1 categorize ISO C char in unsigned integer
97
- // https://github.com/IBM/s390x-abi/releases/tag/v1.6.1
98
- // - z/OS: XL C/C++ Language Reference says: "By default, char behaves like an unsigned char."
99
- // https://www.ibm.com/docs/en/zos/3.1.0?topic=specifiers-character-types
100
- // xtensa:
101
- // Section 2.17.1 "Data Types and Alignment" of Xtensa LX Microprocessor Overview handbook
102
- // says "`char` type is unsigned by default".
103
- // https://loboris.eu/ESP32/Xtensa_lx%20Overview%20handbook.pdf
104
- //
105
- // On the following operating systems, c_char is signed by default, regardless of architecture.
106
- // Darwin (macOS, iOS, etc.):
107
- // Apple targets' c_char is signed by default even on arm
108
- // https://developer.apple.com/documentation/xcode/writing-arm64-code-for-apple-platforms#Handle-data-types-and-data-alignment-properly
109
- // Windows:
110
- // Windows MSVC C++ Language Reference says "Microsoft-specific: Variables of type char
111
- // are promoted to int as if from type signed char by default, unless the /J compilation
112
- // option is used."
113
- // https://learn.microsoft.com/en-us/cpp/cpp/fundamental-types-cpp?view=msvc-170#character-types
114
- // L4Re:
115
- // The kernel builds with -funsigned-char on all targets (but useserspace follows the
116
- // architecture defaults). As we only have a target for userspace apps so there are no
117
- // special cases for L4Re below.
118
- // https://github.com/rust-lang/rust/pull/132975#issuecomment-2484645240
119
- if #[ cfg( all(
120
- not( windows) ,
121
- not( target_vendor = "apple" ) ,
122
- any(
123
- target_arch = "aarch64" ,
124
- target_arch = "arm" ,
125
- target_arch = "csky" ,
126
- target_arch = "hexagon" ,
127
- target_arch = "msp430" ,
128
- target_arch = "powerpc" ,
129
- target_arch = "powerpc64" ,
130
- target_arch = "riscv32" ,
131
- target_arch = "riscv64" ,
132
- target_arch = "s390x" ,
133
- target_arch = "xtensa" ,
134
- )
135
- ) ) ] {
136
- pub ( super ) type c_char = u8 ;
137
- } else {
138
- // On every other target, c_char is signed.
139
- pub ( super ) type c_char = i8 ;
140
- }
141
- }
142
- }
143
-
144
53
mod c_int_definition {
145
54
cfg_if ! {
146
55
if #[ cfg( any( target_arch = "avr" , target_arch = "msp430" ) ) ] {
@@ -152,16 +61,3 @@ mod c_int_definition {
152
61
}
153
62
}
154
63
}
155
-
156
- mod c_long_definition {
157
- cfg_if ! {
158
- if #[ cfg( all( target_pointer_width = "64" , not( windows) ) ) ] {
159
- pub ( super ) type c_long = i64 ;
160
- pub ( super ) type c_ulong = u64 ;
161
- } else {
162
- // The minimal size of `long` in the C standard is 32 bits
163
- pub ( super ) type c_long = i32 ;
164
- pub ( super ) type c_ulong = u32 ;
165
- }
166
- }
167
- }
0 commit comments