mirror of
https://github.com/rust-lang/rust.git
synced 2026-01-24 23:17:31 +00:00
Rollup merge of #151571 - androm3da:bcain/cstr_merge, r=tgross35
Fix cstring-merging test for Hexagon target
Hexagon assembler uses `.string` directive instead of `.asciz` for null-terminated strings. Both are equivalent but the test was only checking for `.asciz`.
Update the CHECK patterns to accept both directives using `.{{asciz|string}}` regex pattern.
This commit is contained in:
@@ -1,5 +1,6 @@
|
||||
// MIPS assembler uses the label prefix `$anon.` for local anonymous variables
|
||||
// other architectures (including ARM and x86-64) use the prefix `.Lanon.`
|
||||
// Hexagon uses `.string` instead of `.asciz` for null-terminated strings
|
||||
//@ only-linux
|
||||
//@ assembly-output: emit-asm
|
||||
//@ compile-flags: --crate-type=lib -Copt-level=3 -Cllvm-args=-enable-global-merge=0
|
||||
@@ -9,13 +10,13 @@ use std::ffi::CStr;
|
||||
|
||||
// CHECK: .section .rodata.str1.{{[12]}},"aMS"
|
||||
// CHECK: {{(\.L|\$)}}anon.{{.+}}:
|
||||
// CHECK-NEXT: .asciz "foo"
|
||||
// CHECK-NEXT: .{{asciz|string}} "foo"
|
||||
#[unsafe(no_mangle)]
|
||||
static CSTR: &[u8; 4] = b"foo\0";
|
||||
|
||||
// CHECK-NOT: .section
|
||||
// CHECK: {{(\.L|\$)}}anon.{{.+}}:
|
||||
// CHECK-NEXT: .asciz "bar"
|
||||
// CHECK-NEXT: .{{asciz|string}} "bar"
|
||||
#[unsafe(no_mangle)]
|
||||
pub fn cstr() -> &'static CStr {
|
||||
c"bar"
|
||||
@@ -23,7 +24,7 @@ pub fn cstr() -> &'static CStr {
|
||||
|
||||
// CHECK-NOT: .section
|
||||
// CHECK: {{(\.L|\$)}}anon.{{.+}}:
|
||||
// CHECK-NEXT: .asciz "baz"
|
||||
// CHECK-NEXT: .{{asciz|string}} "baz"
|
||||
#[unsafe(no_mangle)]
|
||||
pub fn manual_cstr() -> &'static str {
|
||||
"baz\0"
|
||||
|
||||
Reference in New Issue
Block a user