home *** CD-ROM | disk | FTP | other *** search
/ Geek Gadgets 1 / ADE-1.bin / ade-dist / binutils-2.7-src.tgz / tar.out / fsf / binutils / gas / config / tc-m68851.h < prev    next >
C/C++ Source or Header  |  1996-09-28  |  13KB  |  305 lines

  1. /* This file is tc-m68851.h
  2.  
  3.    Copyright (C) 1987-1992 Free Software Foundation, Inc.
  4.    
  5.    This file is part of GAS, the GNU Assembler.
  6.    
  7.    GAS is free software; you can redistribute it and/or modify
  8.    it under the terms of the GNU General Public License as published by
  9.    the Free Software Foundation; either version 2, or (at your option)
  10.    any later version.
  11.    
  12.    GAS is distributed in the hope that it will be useful,
  13.    but WITHOUT ANY WARRANTY; without even the implied warranty of
  14.    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  15.    GNU General Public License for more details.
  16.    
  17.    You should have received a copy of the GNU General Public License
  18.    along with GAS; see the file COPYING.  If not, write to
  19.    the Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
  20.  
  21. /*
  22.  * pmmu.h
  23.  */
  24.  
  25. /* I suppose we have to copyright this file.  Someone on the net sent it
  26.    to us as part of the changes for the m68851 Memory Management Unit */
  27.  
  28. /* Copyright (C) 1987 Free Software Foundation, Inc.
  29.    
  30.    This file is part of Gas, the GNU Assembler.
  31.    
  32.    The GNU assembler is distributed in the hope that it will be
  33.    useful, but WITHOUT ANY WARRANTY.  No author or distributor
  34.    accepts responsibility to anyone for the consequences of using it
  35.    or for whether it serves any particular purpose or works at all,
  36.    unless he says so in writing.  Refer to the GNU Assembler General
  37.    Public License for full details.
  38.    
  39.    Everyone is granted permission to copy, modify and redistribute
  40.    the GNU Assembler, but only under the conditions described in the
  41.    GNU Assembler General Public License.  A copy of this license is
  42.    supposed to have been given to you along with the GNU Assembler
  43.    so you can know your rights and responsibilities.  It should be
  44.    in a file named COPYING.  Among other things, the copyright
  45.    notice and this notice must be preserved on all copies.  */
  46.  
  47. #ifdef m68851
  48.  
  49. /*
  50.   I didn't use much imagination in choosing the 
  51.   following codes, so many of them aren't very
  52.   mnemonic. -rab
  53.   
  54.   P  pmmu register
  55.   Possible values:
  56.   000    TC    Translation Control reg
  57.   100    CAL    Current Access Level
  58.   101    VAL    Validate Access Level
  59.   110    SCC    Stack Change Control
  60.   111    AC    Access Control
  61.   
  62.   W  wide pmmu registers
  63.   Possible values:
  64.   001    DRP    Dma Root Pointer
  65.   010    SRP    Supervisor Root Pointer
  66.   011    CRP    Cpu Root Pointer
  67.   
  68.   f    function code register
  69.   0    SFC
  70.   1    DFC
  71.   
  72.   V    VAL register only
  73.   
  74.   X    BADx, BACx
  75.   100    BAD    Breakpoint Acknowledge Data
  76.   101    BAC    Breakpoint Acknowledge Control
  77.   
  78.   Y    PSR
  79.   Z    PCSR
  80.   
  81.   |    memory         (modes 2-6, 7.*)
  82.   
  83.   */
  84.  
  85. /*
  86.  * these defines should be in m68k.c but
  87.  * i put them here to keep all the m68851 stuff
  88.  * together -rab
  89.  * JF--Make sure these #s don't clash with the ones in m68k.c
  90.  * That would be BAD.
  91.  */
  92. #define TC    (FPS+1)        /* 48 */
  93. #define DRP    (TC+1)        /* 49 */
  94. #define SRP    (DRP+1)        /* 50 */
  95. #define CRP    (SRP+1)        /* 51 */
  96. #define CAL    (CRP+1)        /* 52 */
  97. #define VAL    (CAL+1)        /* 53 */
  98. #define SCC    (VAL+1)        /* 54 */
  99. #define AC    (SCC+1)        /* 55 */
  100. #define BAD    (AC+1)        /* 56,57,58,59, 60,61,62,63 */
  101. #define BAC    (BAD+8)        /* 64,65,66,67, 68,69,70,71 */
  102. #define PSR    (BAC+8)        /* 72 */
  103. #define PCSR    (PSR+1)        /* 73 */
  104.  
  105. /* name */    /* opcode */        /* match */        /* args */
  106.  
  107. {"pbac",    one(0xf0c7),        one(0xffbf),        "Bc"},
  108. {"pbacw",    one(0xf087),        one(0xffbf),        "Bc"},
  109. {"pbas",    one(0xf0c6),        one(0xffbf),        "Bc"},
  110. {"pbasw",    one(0xf086),        one(0xffbf),        "Bc"},
  111. {"pbbc",    one(0xf0c1),        one(0xffbf),        "Bc"},
  112. {"pbbcw",    one(0xf081),        one(0xffbf),        "Bc"},
  113. {"pbbs",    one(0xf0c0),        one(0xffbf),        "Bc"},
  114. {"pbbsw",    one(0xf080),        one(0xffbf),        "Bc"},
  115. {"pbcc",    one(0xf0cf),        one(0xffbf),        "Bc"},
  116. {"pbccw",    one(0xf08f),        one(0xffbf),        "Bc"},
  117. {"pbcs",    one(0xf0ce),        one(0xffbf),        "Bc"},
  118. {"pbcsw",    one(0xf08e),        one(0xffbf),        "Bc"},
  119. {"pbgc",    one(0xf0cd),        one(0xffbf),        "Bc"},
  120. {"pbgcw",    one(0xf08d),        one(0xffbf),        "Bc"},
  121. {"pbgs",    one(0xf0cc),        one(0xffbf),        "Bc"},
  122. {"pbgsw",    one(0xf08c),        one(0xffbf),        "Bc"},
  123. {"pbic",    one(0xf0cb),        one(0xffbf),        "Bc"},
  124. {"pbicw",    one(0xf08b),        one(0xffbf),        "Bc"},
  125. {"pbis",    one(0xf0ca),        one(0xffbf),        "Bc"},
  126. {"pbisw",    one(0xf08a),        one(0xffbf),        "Bc"},
  127. {"pblc",    one(0xf0c3),        one(0xffbf),        "Bc"},
  128. {"pblcw",    one(0xf083),        one(0xffbf),        "Bc"},
  129. {"pbls",    one(0xf0c2),        one(0xffbf),        "Bc"},
  130. {"pblsw",    one(0xf082),        one(0xffbf),        "Bc"},
  131. {"pbsc",    one(0xf0c5),        one(0xffbf),        "Bc"},
  132. {"pbscw",    one(0xf085),        one(0xffbf),        "Bc"},
  133. {"pbss",    one(0xf0c4),        one(0xffbf),        "Bc"},
  134. {"pbssw",    one(0xf084),        one(0xffbf),        "Bc"},
  135. {"pbwc",    one(0xf0c9),        one(0xffbf),        "Bc"},
  136. {"pbwcw",    one(0xf089),        one(0xffbf),        "Bc"},
  137. {"pbws",    one(0xf0c8),        one(0xffbf),        "Bc"},
  138. {"pbwsw",    one(0xf088),        one(0xffbf),        "Bc"},
  139.     
  140.     
  141. {"pdbac",    two(0xf048, 0x0007),    two(0xfff8, 0xffff),    "DsBw"},
  142. {"pdbas",    two(0xf048, 0x0006),    two(0xfff8, 0xffff),    "DsBw"},
  143. {"pdbbc",    two(0xf048, 0x0001),    two(0xfff8, 0xffff),    "DsBw"},
  144. {"pdbbs",    two(0xf048, 0x0000),    two(0xfff8, 0xffff),    "DsBw"},
  145. {"pdbcc",    two(0xf048, 0x000f),    two(0xfff8, 0xffff),    "DsBw"},
  146. {"pdbcs",    two(0xf048, 0x000e),    two(0xfff8, 0xffff),    "DsBw"},
  147. {"pdbgc",    two(0xf048, 0x000d),    two(0xfff8, 0xffff),    "DsBw"},
  148. {"pdbgs",    two(0xf048, 0x000c),    two(0xfff8, 0xffff),    "DsBw"},
  149. {"pdbic",    two(0xf048, 0x000b),    two(0xfff8, 0xffff),    "DsBw"},
  150. {"pdbis",    two(0xf048, 0x000a),    two(0xfff8, 0xffff),    "DsBw"},
  151. {"pdblc",    two(0xf048, 0x0003),    two(0xfff8, 0xffff),    "DsBw"},
  152. {"pdbls",    two(0xf048, 0x0002),    two(0xfff8, 0xffff),    "DsBw"},
  153. {"pdbsc",    two(0xf048, 0x0005),    two(0xfff8, 0xffff),    "DsBw"},
  154. {"pdbss",    two(0xf048, 0x0004),    two(0xfff8, 0xffff),    "DsBw"},
  155. {"pdbwc",    two(0xf048, 0x0009),    two(0xfff8, 0xffff),    "DsBw"},
  156. {"pdbws",    two(0xf048, 0x0008),    two(0xfff8, 0xffff),    "DsBw"},
  157.     
  158. {"pflusha",    two(0xf000, 0x2400),    two(0xffff, 0xffff),    "" },
  159.     
  160. {"pflush",    two(0xf000, 0x3010),    two(0xffc0, 0xfe10),    "T3T9" },
  161. {"pflush",    two(0xf000, 0x3810),    two(0xffc0, 0xfe10),    "T3T9&s" },
  162. {"pflush",    two(0xf000, 0x3008),    two(0xffc0, 0xfe18),    "D3T9" },
  163. {"pflush",    two(0xf000, 0x3808),    two(0xffc0, 0xfe18),    "D3T9&s" },
  164. {"pflush",    two(0xf000, 0x3000),    two(0xffc0, 0xfe1e),    "f3T9" },
  165. {"pflush",    two(0xf000, 0x3800),    two(0xffc0, 0xfe1e),    "f3T9&s" },
  166.     
  167. {"pflushs",    two(0xf000, 0x3410),    two(0xfff8, 0xfe10),    "T3T9" },
  168. {"pflushs",    two(0xf000, 0x3c00),    two(0xfff8, 0xfe00),    "T3T9&s" },
  169. {"pflushs",    two(0xf000, 0x3408),    two(0xfff8, 0xfe18),    "D3T9" },
  170. {"pflushs",    two(0xf000, 0x3c08),    two(0xfff8, 0xfe18),    "D3T9&s" },
  171. {"pflushs",    two(0xf000, 0x3400),    two(0xfff8, 0xfe1e),    "f3T9" },
  172. {"pflushs",    two(0xf000, 0x3c00),    two(0xfff8, 0xfe1e),    "f3T9&s"},
  173.     
  174. {"pflushr",    two(0xf000, 0xa000),    two(0xffc0, 0xffff),    "|s" },
  175.     
  176. {"ploadr",    two(0xf000, 0x2210),    two(0xffc0, 0xfff0),    "T3&s" },
  177. {"ploadr",    two(0xf000, 0x2208),    two(0xffc0, 0xfff8),    "D3&s" },
  178. {"ploadr",    two(0xf000, 0x2200),    two(0xffc0, 0xfffe),    "f3&s" },
  179. {"ploadw",    two(0xf000, 0x2010),    two(0xffc0, 0xfff0),    "T3&s" },
  180. {"ploadw",    two(0xf000, 0x2008),    two(0xffc0, 0xfff8),    "D3&s" },
  181. {"ploadw",    two(0xf000, 0x2000),    two(0xffc0, 0xfffe),    "f3&s" },
  182.     
  183.     /* TC, CRP, DRP, SRP, CAL, VAL, SCC, AC */
  184. {"pmove",    two(0xf000, 0x4000),    two(0xffc0, 0xe3ff),    "*sP8" },
  185. {"pmove",    two(0xf000, 0x4200),    two(0xffc0, 0xe3ff),    "P8%s" },
  186. {"pmove",    two(0xf000, 0x4000),    two(0xffc0, 0xe3ff),    "|sW8" },
  187. {"pmove",    two(0xf000, 0x4200),    two(0xffc0, 0xe3ff),    "W8~s" },
  188.     
  189.     /* BADx, BACx */
  190. {"pmove",    two(0xf000, 0x6200),    two(0xffc0, 0xe3e3),    "*sX3" },
  191. {"pmove",    two(0xf000, 0x6000),    two(0xffc0, 0xe3e3),    "X3%s" },
  192.     
  193.     /* PSR, PCSR */
  194.     /* {"pmove",    two(0xf000, 0x6100),    two(oxffc0, oxffff),    "*sZ8" }, */
  195. {"pmove",    two(0xf000, 0x6000),    two(0xffc0, 0xffff),    "*sY8" },
  196. {"pmove",    two(0xf000, 0x6200),    two(0xffc0, 0xffff),    "Y8%s" },
  197. {"pmove",    two(0xf000, 0x6600),    two(0xffc0, 0xffff),    "Z8%s" },
  198.     
  199. {"prestore",    one(0xf140),        one(0xffc0),        "&s"},
  200. {"prestore",    one(0xf158),        one(0xfff8),        "+s"},
  201. {"psave",    one(0xf100),        one(0xffc0),        "&s"},
  202. {"psave",    one(0xf100),        one(0xffc0),        "+s"},
  203.     
  204. {"psac",    two(0xf040, 0x0007),    two(0xffc0, 0xffff),    "@s"},
  205. {"psas",    two(0xf040, 0x0006),    two(0xffc0, 0xffff),    "@s"},
  206. {"psbc",    two(0xf040, 0x0001),    two(0xffc0, 0xffff),    "@s"},
  207. {"psbs",    two(0xf040, 0x0000),    two(0xffc0, 0xffff),    "@s"},
  208. {"pscc",    two(0xf040, 0x000f),    two(0xffc0, 0xffff),    "@s"},
  209. {"pscs",    two(0xf040, 0x000e),    two(0xffc0, 0xffff),    "@s"},
  210. {"psgc",    two(0xf040, 0x000d),    two(0xffc0, 0xffff),    "@s"},
  211. {"psgs",    two(0xf040, 0x000c),    two(0xffc0, 0xffff),    "@s"},
  212. {"psic",    two(0xf040, 0x000b),    two(0xffc0, 0xffff),    "@s"},
  213. {"psis",    two(0xf040, 0x000a),    two(0xffc0, 0xffff),    "@s"},
  214. {"pslc",    two(0xf040, 0x0003),    two(0xffc0, 0xffff),    "@s"},
  215. {"psls",    two(0xf040, 0x0002),    two(0xffc0, 0xffff),    "@s"},
  216. {"pssc",    two(0xf040, 0x0005),    two(0xffc0, 0xffff),    "@s"},
  217. {"psss",    two(0xf040, 0x0004),    two(0xffc0, 0xffff),    "@s"},
  218. {"pswc",    two(0xf040, 0x0009),    two(0xffc0, 0xffff),    "@s"},
  219. {"psws",    two(0xf040, 0x0008),    two(0xffc0, 0xffff),    "@s"},
  220.     
  221. {"ptestr",    two(0xf000, 0x8210),    two(0xffc0, 0xe3f0),    "T3&sQ8" },
  222. {"ptestr",    two(0xf000, 0x8310),    two(0xffc0, 0xe310),    "T3&sQ8A9" },
  223. {"ptestr",    two(0xf000, 0x8208),    two(0xffc0, 0xe3f8),    "D3&sQ8" },
  224. {"ptestr",    two(0xf000, 0x8308),    two(0xffc0, 0xe318),    "D3&sQ8A9" },
  225. {"ptestr",    two(0xf000, 0x8200),    two(0xffc0, 0xe3fe),    "f3&sQ8" },
  226. {"ptestr",    two(0xf000, 0x8300),    two(0xffc0, 0xe31e),    "f3&sQ8A9" },
  227.     
  228. {"ptestw",    two(0xf000, 0x8010),    two(0xffc0, 0xe3f0),    "T3&sQ8" },
  229. {"ptestw",    two(0xf000, 0x8110),    two(0xffc0, 0xe310),    "T3&sQ8A9" },
  230. {"ptestw",    two(0xf000, 0x8008),    two(0xffc0, 0xe3f8),    "D3&sQ8" },
  231. {"ptestw",    two(0xf000, 0x8108),    two(0xffc0, 0xe318),    "D3&sQ8A9" },
  232. {"ptestw",    two(0xf000, 0x8000),    two(0xffc0, 0xe3fe),    "f3&sQ8" },
  233. {"ptestw",    two(0xf000, 0x8100),    two(0xffc0, 0xe31e),    "f3&sQ8A9" },
  234.     
  235. {"ptrapacw",    two(0xf07a, 0x0007),    two(0xffff, 0xffff),    "#w"},
  236. {"ptrapacl",    two(0xf07b, 0x0007),    two(0xffff, 0xffff),    "#l"},
  237. {"ptrapac",    two(0xf07c, 0x0007),    two(0xffff, 0xffff),    ""},
  238.     
  239. {"ptrapasw",    two(0xf07a, 0x0006),    two(0xffff, 0xffff),    "#w"},
  240. {"ptrapasl",    two(0xf07b, 0x0006),    two(0xffff, 0xffff),    "#l"},
  241. {"ptrapas",    two(0xf07c, 0x0006),    two(0xffff, 0xffff),    ""},
  242.     
  243. {"ptrapbcw",    two(0xf07a, 0x0001),    two(0xffff, 0xffff),    "#w"},
  244. {"ptrapbcl",    two(0xf07b, 0x0001),    two(0xffff, 0xffff),    "#l"},
  245. {"ptrapbc",    two(0xf07c, 0x0001),    two(0xffff, 0xffff),    ""},
  246.     
  247. {"ptrapbsw",    two(0xf07a, 0x0000),    two(0xffff, 0xffff),    "#w"},
  248. {"ptrapbsl",    two(0xf07b, 0x0000),    two(0xffff, 0xffff),    "#l"},
  249. {"ptrapbs",    two(0xf07c, 0x0000),    two(0xffff, 0xffff),    ""},
  250.     
  251. {"ptrapccw",    two(0xf07a, 0x000f),    two(0xffff, 0xffff),    "#w"},
  252. {"ptrapccl",    two(0xf07b, 0x000f),    two(0xffff, 0xffff),    "#l"},
  253. {"ptrapcc",    two(0xf07c, 0x000f),    two(0xffff, 0xffff),    ""},
  254.     
  255. {"ptrapcsw",    two(0xf07a, 0x000e),    two(0xffff, 0xffff),    "#w"},
  256. {"ptrapcsl",    two(0xf07b, 0x000e),    two(0xffff, 0xffff),    "#l"},
  257. {"ptrapcs",    two(0xf07c, 0x000e),    two(0xffff, 0xffff),    ""},
  258.     
  259. {"ptrapgcw",    two(0xf07a, 0x000d),    two(0xffff, 0xffff),    "#w"},
  260. {"ptrapgcl",    two(0xf07b, 0x000d),    two(0xffff, 0xffff),    "#l"},
  261. {"ptrapgc",    two(0xf07c, 0x000d),    two(0xffff, 0xffff),    ""},
  262.     
  263. {"ptrapgsw",    two(0xf07a, 0x000c),    two(0xffff, 0xffff),    "#w"},
  264. {"ptrapgsl",    two(0xf07b, 0x000c),    two(0xffff, 0xffff),    "#l"},
  265. {"ptrapgs",    two(0xf07c, 0x000c),    two(0xffff, 0xffff),    ""},
  266.     
  267. {"ptrapicw",    two(0xf07a, 0x000b),    two(0xffff, 0xffff),    "#w"},
  268. {"ptrapicl",    two(0xf07b, 0x000b),    two(0xffff, 0xffff),    "#l"},
  269. {"ptrapic",    two(0xf07c, 0x000b),    two(0xffff, 0xffff),    ""},
  270.     
  271. {"ptrapisw",    two(0xf07a, 0x000a),    two(0xffff, 0xffff),    "#w"},
  272. {"ptrapisl",    two(0xf07b, 0x000a),    two(0xffff, 0xffff),    "#l"},
  273. {"ptrapis",    two(0xf07c, 0x000a),    two(0xffff, 0xffff),    ""},
  274.     
  275. {"ptraplcw",    two(0xf07a, 0x0003),    two(0xffff, 0xffff),    "#w"},
  276. {"ptraplcl",    two(0xf07b, 0x0003),    two(0xffff, 0xffff),    "#l"},
  277. {"ptraplc",    two(0xf07c, 0x0003),    two(0xffff, 0xffff),    ""},
  278.     
  279. {"ptraplsw",    two(0xf07a, 0x0002),    two(0xffff, 0xffff),    "#w"},
  280. {"ptraplsl",    two(0xf07b, 0x0002),    two(0xffff, 0xffff),    "#l"},
  281. {"ptrapls",    two(0xf07c, 0x0002),    two(0xffff, 0xffff),    ""},
  282.     
  283. {"ptrapscw",    two(0xf07a, 0x0005),    two(0xffff, 0xffff),    "#w"},
  284. {"ptrapscl",    two(0xf07b, 0x0005),    two(0xffff, 0xffff),    "#l"},
  285. {"ptrapsc",    two(0xf07c, 0x0005),    two(0xffff, 0xffff),    ""},
  286.     
  287. {"ptrapssw",    two(0xf07a, 0x0004),    two(0xffff, 0xffff),    "#w"},
  288. {"ptrapssl",    two(0xf07b, 0x0004),    two(0xffff, 0xffff),    "#l"},
  289. {"ptrapss",    two(0xf07c, 0x0004),    two(0xffff, 0xffff),    ""},
  290.     
  291. {"ptrapwcw",    two(0xf07a, 0x0009),    two(0xffff, 0xffff),    "#w"},
  292. {"ptrapwcl",    two(0xf07b, 0x0009),    two(0xffff, 0xffff),    "#l"},
  293. {"ptrapwc",    two(0xf07c, 0x0009),    two(0xffff, 0xffff),    ""},
  294.     
  295. {"ptrapwsw",    two(0xf07a, 0x0008),    two(0xffff, 0xffff),    "#w"},
  296. {"ptrapwsl",    two(0xf07b, 0x0008),    two(0xffff, 0xffff),    "#l"},
  297. {"ptrapws",    two(0xf07c, 0x0008),    two(0xffff, 0xffff),    ""},
  298.     
  299. {"pvalid",    two(0xf000, 0x2800),    two(0xffc0, 0xffff),    "Vs&s"},
  300. {"pvalid",    two(0xf000, 0x2c00),    two(0xffc0, 0xfff8),    "A3&s" },
  301.     
  302. #endif /* m68851 */
  303.  
  304. /* end of tc-m68851.h */
  305.