hc
2025-02-14 bbb9540dc49f70f6b703d1c8d1b85fa5f602d86e
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef _SPARC_ASM_H
#define _SPARC_ASM_H
 
/* Macros to assist the sharing of assembler code between 32-bit and
 * 64-bit sparc.
 */
 
#ifdef CONFIG_SPARC64
#define BRANCH32(TYPE, PREDICT, DEST) \
   TYPE,PREDICT    %icc, DEST
#define BRANCH32_ANNUL(TYPE, PREDICT, DEST) \
   TYPE,a,PREDICT    %icc, DEST
#define BRANCH_REG_ZERO(PREDICT, REG, DEST) \
   brz,PREDICT    REG, DEST
#define BRANCH_REG_ZERO_ANNUL(PREDICT, REG, DEST) \
   brz,a,PREDICT    REG, DEST
#define BRANCH_REG_NOT_ZERO(PREDICT, REG, DEST) \
   brnz,PREDICT    REG, DEST
#define BRANCH_REG_NOT_ZERO_ANNUL(PREDICT, REG, DEST) \
   brnz,a,PREDICT    REG, DEST
#else
#define BRANCH32(TYPE, PREDICT, DEST) \
   TYPE        DEST
#define BRANCH32_ANNUL(TYPE, PREDICT, DEST) \
   TYPE,a        DEST
#define BRANCH_REG_ZERO(PREDICT, REG, DEST) \
   cmp        REG, 0; \
   be        DEST
#define BRANCH_REG_ZERO_ANNUL(PREDICT, REG, DEST) \
   cmp        REG, 0; \
   be,a        DEST
#define BRANCH_REG_NOT_ZERO(PREDICT, REG, DEST) \
   cmp        REG, 0; \
   bne        DEST
#define BRANCH_REG_NOT_ZERO_ANNUL(PREDICT, REG, DEST) \
   cmp        REG, 0; \
   bne,a        DEST
#endif
 
#endif /* _SPARC_ASM_H */