Blame view

kernel/linux-imx6_3.14.28/arch/powerpc/xmon/spu.h 3.55 KB
6b13f685e   김민수   BSP 최초 추가
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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
  /* SPU ELF support for BFD.
  
     Copyright 2006 Free Software Foundation, Inc.
  
     This file is part of GDB, GAS, and the GNU binutils.
  
     This program is free software; you can redistribute it and/or modify
     it under the terms of the GNU General Public License as published by
     the Free Software Foundation; either version 2 of the License, or
     (at your option) any later version.
  
     This program is distributed in the hope that it will be useful,
     but WITHOUT ANY WARRANTY; without even the implied warranty of
     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     GNU General Public License for more details.
  
     You should have received a copy of the GNU General Public License
     along with this program; if not, write to the Free Software Foundation,
     Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.  */
  
  
  /* These two enums are from rel_apu/common/spu_asm_format.h */
  /* definition of instruction format */
  typedef enum {
    RRR,
    RI18,
    RI16,
    RI10,
    RI8,
    RI7,
    RR,
    LBT,
    LBTI,
    IDATA,
    UNKNOWN_IFORMAT
  } spu_iformat;
  
  /* These values describe assembly instruction arguments.  They indicate
   * how to encode, range checking and which relocation to use. */
  typedef enum {
    A_T,  /* register at pos 0 */
    A_A,  /* register at pos 7 */
    A_B,  /* register at pos 14 */
    A_C,  /* register at pos 21 */
    A_S,  /* special purpose register at pos 7 */
    A_H,  /* channel register at pos 7 */
    A_P,  /* parenthesis, this has to separate regs from immediates */
    A_S3,
    A_S6,
    A_S7N,
    A_S7,
    A_U7A,
    A_U7B,
    A_S10B,
    A_S10,
    A_S11,
    A_S11I,
    A_S14,
    A_S16,
    A_S18,
    A_R18,
    A_U3,
    A_U5,
    A_U6,
    A_U7,
    A_U14,
    A_X16,
    A_U18,
    A_MAX
  } spu_aformat;
  
  enum spu_insns {
  #define APUOP(TAG,MACFORMAT,OPCODE,MNEMONIC,ASMFORMAT,DEP,PIPE) \
  	TAG,
  #define APUOPFB(TAG,MACFORMAT,OPCODE,FB,MNEMONIC,ASMFORMAT,DEP,PIPE) \
  	TAG,
  #include "spu-insns.h"
  #undef APUOP
  #undef APUOPFB
          M_SPU_MAX
  };
  
  struct spu_opcode
  {
     spu_iformat insn_type;
     unsigned int opcode;
     char *mnemonic;
     int arg[5];
  };
  
  #define SIGNED_EXTRACT(insn,size,pos) (((int)((insn) << (32-size-pos))) >> (32-size))
  #define UNSIGNED_EXTRACT(insn,size,pos) (((insn) >> pos) & ((1 << size)-1))
  
  #define DECODE_INSN_RT(insn) (insn & 0x7f)
  #define DECODE_INSN_RA(insn) ((insn >> 7) & 0x7f)
  #define DECODE_INSN_RB(insn) ((insn >> 14) & 0x7f)
  #define DECODE_INSN_RC(insn) ((insn >> 21) & 0x7f)
  
  #define DECODE_INSN_I10(insn) SIGNED_EXTRACT(insn,10,14)
  #define DECODE_INSN_U10(insn) UNSIGNED_EXTRACT(insn,10,14)
  
  /* For branching, immediate loads, hbr and  lqa/stqa. */
  #define DECODE_INSN_I16(insn) SIGNED_EXTRACT(insn,16,7)
  #define DECODE_INSN_U16(insn) UNSIGNED_EXTRACT(insn,16,7)
  
  /* for stop */
  #define DECODE_INSN_U14(insn) UNSIGNED_EXTRACT(insn,14,0)
  
  /* For ila */
  #define DECODE_INSN_I18(insn) SIGNED_EXTRACT(insn,18,7)
  #define DECODE_INSN_U18(insn) UNSIGNED_EXTRACT(insn,18,7)
  
  /* For rotate and shift and generate control mask */
  #define DECODE_INSN_I7(insn) SIGNED_EXTRACT(insn,7,14)
  #define DECODE_INSN_U7(insn) UNSIGNED_EXTRACT(insn,7,14)
  
  /* For float <-> int conversion */
  #define DECODE_INSN_I8(insn)  SIGNED_EXTRACT(insn,8,14)
  #define DECODE_INSN_U8(insn) UNSIGNED_EXTRACT(insn,8,14)
  
  /* For hbr  */
  #define DECODE_INSN_I9a(insn) ((SIGNED_EXTRACT(insn,2,23) << 7) | UNSIGNED_EXTRACT(insn,7,0))
  #define DECODE_INSN_I9b(insn) ((SIGNED_EXTRACT(insn,2,14) << 7) | UNSIGNED_EXTRACT(insn,7,0))
  #define DECODE_INSN_U9a(insn) ((UNSIGNED_EXTRACT(insn,2,23) << 7) | UNSIGNED_EXTRACT(insn,7,0))
  #define DECODE_INSN_U9b(insn) ((UNSIGNED_EXTRACT(insn,2,14) << 7) | UNSIGNED_EXTRACT(insn,7,0))