summaryrefslogtreecommitdiff
path: root/sim/ucsim/tlcs.src/inst_bit.cc
diff options
context:
space:
mode:
authorXavier ASUS <xavi92psx@gmail.com>2019-10-18 00:31:54 +0200
committerXavier ASUS <xavi92psx@gmail.com>2019-10-18 00:31:54 +0200
commit268a53de823a6750d6256ee1fb1e7707b4b45740 (patch)
tree42c1799a9a82b2f7d9790ee9fe181d72a7274751 /sim/ucsim/tlcs.src/inst_bit.cc
downloadsdcc-gas-268a53de823a6750d6256ee1fb1e7707b4b45740.tar.gz
sdcc-3.9.0 fork implementing GNU assembler syntax
This fork aims to provide better support for stm8-binutils
Diffstat (limited to 'sim/ucsim/tlcs.src/inst_bit.cc')
-rw-r--r--sim/ucsim/tlcs.src/inst_bit.cc138
1 files changed, 138 insertions, 0 deletions
diff --git a/sim/ucsim/tlcs.src/inst_bit.cc b/sim/ucsim/tlcs.src/inst_bit.cc
new file mode 100644
index 0000000..1ac2932
--- /dev/null
+++ b/sim/ucsim/tlcs.src/inst_bit.cc
@@ -0,0 +1,138 @@
+/*
+ * Simulator of microcontrollers (tlcs.src/inst_bit.cc)
+ *
+ * Copyright (C) 2016,16 Drotos Daniel, Talker Bt.
+ *
+ * To contact author send email to drdani@mazsola.iit.uni-miskolc.hu
+ *
+ */
+
+/* This file is part of microcontroller simulator: ucsim.
+
+UCSIM 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.
+
+UCSIM 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 UCSIM; see the file COPYING. If not, write to the Free
+Software Foundation, 59 Temple Place - Suite 330, Boston, MA
+02111-1307, USA. */
+/*@1@*/
+
+#include "tlcscl.h"
+
+
+// TSET 8-bit
+u8_t
+cl_tlcs::op_tset(u8_t val, u8_t bitnr)
+{
+ reg.raf.f&= ~(FLAG_Z|FLAG_N);
+ reg.raf.f|= FLAG_H;
+
+ bitnr&= 0x07;
+ if ((val & (1 << bitnr)) == 0)
+ reg.raf.f|= FLAG_Z;
+ val|= (1 << bitnr);
+ return val;
+}
+
+
+// TSET mem
+u8_t
+cl_tlcs::inst_tset(cl_memory_cell *cell, u8_t bitnr)
+{
+ u8_t v= cell->read();
+ vc.rd++;
+ v= op_tset(v, bitnr);
+ cell->write(v);
+ vc.wr++;
+ return v;
+}
+
+
+// BIT 8-bit
+u8_t
+cl_tlcs::op_bit(u8_t val, u8_t bitnr)
+{
+ reg.raf.f&= ~(FLAG_Z|FLAG_N);
+ reg.raf.f|= FLAG_H;
+
+ bitnr&= 7;
+
+ if ((val & (1 << bitnr)) == 0)
+ reg.raf.f|= FLAG_Z;
+
+ return val;
+}
+
+
+// BIT mem
+u8_t
+cl_tlcs::inst_bit(cl_memory_cell *cell, u8_t bitnr)
+{
+ u8_t v= cell->read();
+ vc.rd++;
+ v= op_bit(v, bitnr);
+ cell->write(v);
+ vc.wr++;
+ return v;
+}
+
+
+// RES 8-bit
+u8_t
+cl_tlcs::op_res(u8_t val, u8_t bitnr)
+{
+ bitnr&= 7;
+
+ val&= ~(1 << bitnr);
+
+ return val;
+}
+
+
+// RES mem
+u8_t
+cl_tlcs::inst_res(cl_memory_cell *cell, u8_t bitnr)
+{
+ u8_t v= cell->read();
+ vc.rd++;
+ v= op_res(v, bitnr);
+ cell->write(v);
+ vc.wr++;
+ return v;
+}
+
+
+// SET 8-bit
+u8_t
+cl_tlcs::op_set(u8_t val, u8_t bitnr)
+{
+ bitnr&= 7;
+
+ val|= (1 << bitnr);
+
+ return val;
+}
+
+
+// SET mem
+u8_t
+cl_tlcs::inst_set(cl_memory_cell *cell, u8_t bitnr)
+{
+ u8_t v= cell->read();
+ vc.rd++;
+ v= op_set(v, bitnr);
+ cell->write(v);
+ vc.wr++;
+ return v;
+}
+
+
+/* End of tlcs.src/inst_bit.cc */