123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116 |
- {
- $Id$
- Copyright (c) 1998-2002 by Florian Klaempfl
- This unit contains the m68k GAS instruction tables
- 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., 675 Mass Ave, Cambridge, MA 02139, USA.
- ****************************************************************************
- }
- unit itcpugas;
- {$i fpcdefs.inc}
- interface
- uses
- cpubase,cgbase;
- const
- gas_op2str : op2strtable=
- { warning: CPU32 opcodes are not fully compatible with the MC68020. }
- { 68000 only opcodes }
- ('abcd',
- 'add','adda','addi','addq','addx','and','andi',
- 'asl','asr','bcc','bcs','beq','bge','bgt','bhi',
- 'ble','bls','blt','bmi','bne','bpl','bvc','bvs',
- 'bchg','bclr','bra','bset','bsr','btst','chk',
- 'clr','cmp','cmpa','cmpi','cmpm','dbcc','dbcs','dbeq','dbge',
- 'dbgt','dbhi','dble','dbls','dblt','dbmi','dbne','dbra',
- 'dbpl','dbt','dbvc','dbvs','dbf','divs','divu',
- 'eor','eori','exg','illegal','ext','jmp','jsr',
- 'lea','link','lsl','lsr','move','movea','movei','moveq',
- 'movem','movep','muls','mulu','nbcd','neg','negx',
- 'nop','not','or','ori','pea','rol','ror','roxl',
- 'roxr','rtr','rts','sbcd','scc','scs','seq','sge',
- 'sgt','shi','sle','sls','slt','smi','sne',
- 'spl','st','svc','svs','sf','sub','suba','subi','subq',
- 'subx','swap','tas','trap','trapv','tst','unlk',
- 'rte','reset','stop',
- { mc68010 instructions }
- 'bkpt','movec','moves','rtd',
- { mc68020 instructions }
- 'bfchg','bfclr','bfexts','bfextu','bfffo',
- 'bfins','bfset','bftst','callm','cas','cas2',
- 'chk2','cmp2','divsl','divul','extb','pack','rtm',
- 'trapcc','tracs','trapeq','trapf','trapge','trapgt',
- 'traphi','traple','trapls','traplt','trapmi','trapne',
- 'trappl','trapt','trapvc','trapvs','unpk',
- { fpu processor instructions - directly supported only. }
- { ieee aware and misc. condition codes not supported }
- 'fabs','fadd',
- 'fbeq','fbne','fbngt','fbgt','fbge','fbnge',
- 'fblt','fbnlt','fble','fbgl','fbngl','fbgle','fbngle',
- 'fdbeq','fdbne','fdbgt','fdbngt','fdbge','fdbnge',
- 'fdblt','fdbnlt','fdble','fdbgl','fdbngl','fdbgle','fdbngle',
- 'fseq','fsne','fsgt','fsngt','fsge','fsnge',
- 'fslt','fsnlt','fsle','fsgl','fsngl','fsgle','fsngle',
- 'fcmp','fdiv','fmove','fmovem',
- 'fmul','fneg','fnop','fsqrt','fsub','fsgldiv',
- 'fsflmul','ftst',
- 'ftrapeq','ftrapne','ftrapgt','ftrapngt','ftrapge','ftrapnge',
- 'ftraplt','ftrapnlt','ftraple','ftrapgl','ftrapngl','ftrapgle','ftrapngle',
- { protected instructions }
- 'cprestore','cpsave',
- { fpu unit protected instructions }
- { and 68030/68851 common mmu instructions }
- { (this may include 68040 mmu instructions) }
- 'frestore','fsave','pflush','pflusha','pload','pmove','ptest',
- { useful for assembly language output }
- 'label','none','db','s','b','fb');
- function gas_regnum_search(const s:string):Tregister;
- function gas_regname(r:Tregister):string;
- implementation
- const
- gas_reg2str : array[tregisterindex] of string[7] = (
- ('', '%d0','%d1','%d2','%d3','%d4','%d5','%d6','%d7',
- '%a0','%a1','%a2','%a3','%a4','%a5','%a6','%sp',
- '%ccr','%fp0','%fp1','%fp2','%fp3','%fp4','%fp5',
- '%fp6','%fp7','%fpcr','%sr','%ssp','%dfc',
- '%sfc','%vbr','%fpsr');
- function gas_regnum_search(const s:string):Tregister;
- begin
- result:=std_regnum_search(s);
- end;
- function gas_regname(r:Tregister):string;
- begin
- result:=std_regname(r);
- end;
- end.
- {
- $Log$
- Revision 1.1 2004-04-27 05:43:42 florian
- * initial revision
- }
|