1 // SPDX-License-Identifier: GPL-2.0-or-later
3 * Ptrace test for GPR/FPR registers in TM context
5 * Copyright (C) 2015 Anshuman Khandual, IBM Corporation.
8 #include "ptrace-gpr.h"
11 /* Tracer and Tracee Shared Data */
13 unsigned long *cptr
, *pptr
;
21 unsigned long gpr_buf
[18];
22 unsigned long result
, texasr
;
25 printf("Starting the child\n");
26 cptr
= (unsigned long *)shmat(shm_id
, NULL
, 0);
31 ASM_LOAD_GPR_IMMED(gpr_1
)
32 ASM_LOAD_FPR_SINGLE_PRECISION(flt_1
)
36 ASM_LOAD_GPR_IMMED(gpr_2
)
37 ASM_LOAD_FPR_SINGLE_PRECISION(flt_2
)
49 /* Transaction abort handler */
53 "mfspr %[texasr], %[sprn_texasr];"
56 : [res
] "=r" (result
), [texasr
] "=r" (texasr
)
57 : [gpr_1
]"i"(GPR_1
), [gpr_2
]"i"(GPR_2
),
58 [sprn_texasr
] "i" (SPRN_TEXASR
), [flt_1
] "b" (&a
),
59 [flt_2
] "b" (&b
), [cptr1
] "b" (&cptr
[1])
60 : "memory", "r7", "r8", "r9", "r10",
61 "r11", "r12", "r13", "r14", "r15", "r16",
62 "r17", "r18", "r19", "r20", "r21", "r22",
63 "r23", "r24", "r25", "r26", "r27", "r28",
73 store_fpr_single_precision(fpr_buf
);
75 if (validate_gpr(gpr_buf
, GPR_3
))
78 if (validate_fpr_float(fpr_buf
, c
))
87 int trace_tm_gpr(pid_t child
)
89 unsigned long gpr
[18];
90 unsigned long fpr
[32];
92 FAIL_IF(start_trace(child
));
93 FAIL_IF(show_gpr(child
, gpr
));
94 FAIL_IF(validate_gpr(gpr
, GPR_2
));
95 FAIL_IF(show_fpr(child
, fpr
));
96 FAIL_IF(validate_fpr(fpr
, FPR_2_REP
));
97 FAIL_IF(show_ckpt_fpr(child
, fpr
));
98 FAIL_IF(validate_fpr(fpr
, FPR_1_REP
));
99 FAIL_IF(show_ckpt_gpr(child
, gpr
));
100 FAIL_IF(validate_gpr(gpr
, GPR_1
));
101 FAIL_IF(write_ckpt_gpr(child
, GPR_3
));
102 FAIL_IF(write_ckpt_fpr(child
, FPR_3_REP
));
105 FAIL_IF(stop_trace(child
));
110 int ptrace_tm_gpr(void)
115 SKIP_IF(!have_htm());
116 shm_id
= shmget(IPC_PRIVATE
, sizeof(int) * 2, 0777|IPC_CREAT
);
119 perror("fork() failed");
126 pptr
= (unsigned long *)shmat(shm_id
, NULL
, 0);
129 asm volatile("" : : : "memory");
130 ret
= trace_tm_gpr(pid
);
139 shmctl(shm_id
, IPC_RMID
, NULL
);
141 printf("Child's exit status not captured\n");
145 return (WIFEXITED(status
) && WEXITSTATUS(status
)) ? TEST_FAIL
:
151 int main(int argc
, char *argv
[])
153 return test_harness(ptrace_tm_gpr
, "ptrace_tm_gpr");