This is the mail archive of the gdb-patches@sources.redhat.com mailing list for the GDB project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

[PATCH/RFA] h8300 sim: add daa and das insns


Here's my implementation of daa/das:
2003-04-07  Michael Snyder  <msnyder at redhat dot com>

	* compile.c (sim_resume): Implement daa and das insns.

Index: compile.c
===================================================================
RCS file: /cvs/cvsfiles/devo/sim/h8300/compile.c,v
retrieving revision 1.70
diff -p -r1.70 compile.c
*** compile.c	2003/03/27 22:01:29	1.70
--- compile.c	2003/04/08 06:20:31
*************** sim_resume (SIM_DESC sd, int step, int s
*** 2138,2143 ****
--- 2146,2202 ----
  	  }
  	  goto next;
  
+ 	case O (O_DAA, SB):
+ 	  /* Decimal Adjust Addition.  This is for BCD arithmetic.  */
+ 	  res = GET_B_REG (code->src.reg);
+ 	  if (!c && (0 <= (res >>  4) && (res >>  4) <= 9) && 
+ 	      !h && (0 <= (res & 0xf) && (res & 0xf) <= 9))
+ 	    res = res;		/* Value added == 0.  */
+ 	  else if (!c && (0  <= (res >>  4) && (res >>  4) <=  8) && 
+ 		   !h && (10 <= (res & 0xf) && (res & 0xf) <= 15))
+ 	    res = res + 0x6;		/* Value added == 6.  */
+ 	  else if (!c && (0 <= (res >>  4) && (res >>  4) <= 9) && 
+ 		    h && (0 <= (res & 0xf) && (res & 0xf) <= 3))
+ 	    res = res + 0x6;		/* Value added == 6.  */
+ 	  else if (!c && (10 <= (res >>  4) && (res >>  4) <= 15) && 
+ 		   !h && (0  <= (res & 0xf) && (res & 0xf) <=  9))
+ 	    res = res + 0x60;		/* Value added == 60.  */
+ 	  else if (!c && (9  <= (res >>  4) && (res >>  4) <= 15) && 
+ 		   !h && (10 <= (res & 0xf) && (res & 0xf) <= 15))
+ 	    res = res + 0x66;		/* Value added == 66.  */
+ 	  else if (!c && (10 <= (res >>  4) && (res >>  4) <= 15) && 
+ 		    h && (0  <= (res & 0xf) && (res & 0xf) <=  3))
+ 	    res = res + 0x66;		/* Value added == 66.  */
+ 	  else if ( c && (1 <= (res >>  4) && (res >>  4) <= 2) && 
+ 		   !h && (0 <= (res & 0xf) && (res & 0xf) <= 9))
+ 	    res = res + 0x60;		/* Value added == 60.  */
+ 	  else if ( c && (1  <= (res >>  4) && (res >>  4) <=  2) && 
+ 		   !h && (10 <= (res & 0xf) && (res & 0xf) <= 15))
+ 	    res = res + 0x66;		/* Value added == 66.  */
+ 	  else if (c && (1 <= (res >>  4) && (res >>  4) <= 3) && 
+ 		   h && (0 <= (res & 0xf) && (res & 0xf) <= 3))
+ 	    res = res + 0x66;		/* Value added == 66.  */
+ 
+ 	  goto alu8;
+ 
+ 	case O (O_DAS, SB):
+ 	  /* Decimal Adjust Subtraction.  This is for BCD arithmetic.  */
+ 	  res = GET_B_REG (code->src.reg); /* FIXME fetch, fetch2... */
+ 	  if (!c && (0 <= (res >>  4) && (res >>  4) <= 9) && 
+ 	      !h && (0 <= (res & 0xf) && (res & 0xf) <= 9))
+ 	    res = res;		/* Value added == 0.  */
+ 	  else if (!c && (0 <= (res >>  4) && (res >>  4) <=  8) && 
+ 		    h && (6 <= (res & 0xf) && (res & 0xf) <= 15))
+ 	    res = res + 0xfa;		/* Value added == 0xfa.  */
+ 	  else if ( c && (7 <= (res >>  4) && (res >>  4) <= 15) && 
+ 		   !h && (0 <= (res & 0xf) && (res & 0xf) <=  9))
+ 	    res = res + 0xa0;		/* Value added == 0xa0.  */
+ 	  else if (c && (6 <= (res >>  4) && (res >>  4) <= 15) && 
+ 		   h && (6 <= (res & 0xf) && (res & 0xf) <= 15))
+ 	    res = res + 0x9a;		/* Value added == 0x9a.  */
+ 
+ 	  goto alu8;
+ 
  	default:
  	illegal:
  	  cpu.state = SIM_STATE_STOPPED;

Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]