From 1079712260f2327e4d81e9f013ba134eaa0cac3b Mon Sep 17 00:00:00 2001 From: Nicholas Kirchner Date: Thu, 22 Aug 2013 20:01:12 -0500 Subject: [PATCH] deleted .svn subdirectories --- .gitignore | 2 + bitmaps/.svn/all-wcprops | 545 - bitmaps/.svn/entries | 3091 ------ bitmaps/.svn/text-base/ann_alpha.xbm.svn-base | 5 - .../.svn/text-base/ann_battery.xbm.svn-base | 5 - bitmaps/.svn/text-base/ann_busy.xbm.svn-base | 5 - bitmaps/.svn/text-base/ann_io.xbm.svn-base | 5 - bitmaps/.svn/text-base/ann_left.xbm.svn-base | 5 - bitmaps/.svn/text-base/ann_right.xbm.svn-base | 5 - .../.svn/text-base/button_large.xbm.svn-base | 19 - .../.svn/text-base/button_normal.xbm.svn-base | 17 - .../.svn/text-base/button_round.pix.svn-base | 157 - .../.svn/text-base/button_round.xbm.svn-base | 17 - .../.svn/text-base/button_small.xbm.svn-base | 15 - .../.svn/text-base/button_tiny.xbm.svn-base | 13 - bitmaps/.svn/text-base/tiny_A.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_B.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_C.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_D.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_E.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_F.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_G.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_H.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_I.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_J.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_K.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_L.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_M.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_N.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_O.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_P.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_Q.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_R.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_S.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_T.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_U.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_V.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_W.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_X.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_Y.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_Z.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny__i.xbm.svn-base | 6 - .../text-base/tiny_ampersand.xbm.svn-base | 6 - .../text-base/tiny_arrowleft.xbm.svn-base | 6 - .../text-base/tiny_arrowright.xbm.svn-base | 6 - .../text-base/tiny_braceleft.xbm.svn-base | 6 - .../text-base/tiny_braceright.xbm.svn-base | 6 - .../text-base/tiny_bracketleft.xbm.svn-base | 6 - .../text-base/tiny_bracketright.xbm.svn-base | 6 - .../.svn/text-base/tiny_colon.xbm.svn-base | 6 - .../.svn/text-base/tiny_comma.xbm.svn-base | 6 - .../.svn/text-base/tiny_equal.xbm.svn-base | 6 - .../.svn/text-base/tiny_greater.xbm.svn-base | 6 - .../text-base/tiny_guillemotleft.xbm.svn-base | 6 - .../tiny_guillemotright.xbm.svn-base | 6 - .../.svn/text-base/tiny_hyphen.xbm.svn-base | 6 - .../text-base/tiny_large_comma.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_less.xbm.svn-base | 6 - .../tiny_math_arrowleft.xbm.svn-base | 7 - .../tiny_math_arrowright.xbm.svn-base | 7 - .../tiny_math_downarrowleft.xbm.svn-base | 7 - .../tiny_math_downarrowright.xbm.svn-base | 7 - .../.svn/text-base/tiny_math_e.xbm.svn-base | 6 - .../text-base/tiny_math_equal.xbm.svn-base | 6 - .../text-base/tiny_math_greater.xbm.svn-base | 6 - .../tiny_math_greaterequal.xbm.svn-base | 6 - .../text-base/tiny_math_infinity.xbm.svn-base | 6 - .../text-base/tiny_math_integral.xbm.svn-base | 7 - .../text-base/tiny_math_less.xbm.svn-base | 6 - .../tiny_math_lessequal.xbm.svn-base | 6 - .../text-base/tiny_math_notequal.xbm.svn-base | 6 - .../tiny_math_numbersign.xbm.svn-base | 7 - .../tiny_math_partialdiff.xbm.svn-base | 6 - .../.svn/text-base/tiny_math_pi.xbm.svn-base | 7 - .../text-base/tiny_math_radical.xbm.svn-base | 6 - .../tiny_math_summation.xbm.svn-base | 6 - .../.svn/text-base/tiny_math_x.xbm.svn-base | 6 - .../.svn/text-base/tiny_math_y.xbm.svn-base | 6 - .../.svn/text-base/tiny_notdef.xbm.svn-base | 6 - .../text-base/tiny_numbersign.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_one.xbm.svn-base | 6 - .../text-base/tiny_overscore.xbm.svn-base | 6 - .../text-base/tiny_parenleft.xbm.svn-base | 6 - .../text-base/tiny_parenright.xbm.svn-base | 6 - .../.svn/text-base/tiny_period.xbm.svn-base | 6 - .../.svn/text-base/tiny_quotedbl.xbm.svn-base | 6 - .../.svn/text-base/tiny_slash.xbm.svn-base | 6 - .../.svn/text-base/tiny_three.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_two.xbm.svn-base | 6 - .../text-base/tiny_twosuperior.xbm.svn-base | 6 - .../text-base/tiny_underscore.xbm.svn-base | 6 - .../text-base/tiny_xsuperior.xbm.svn-base | 6 - bitmaps/.svn/text-base/tiny_zero.xbm.svn-base | 6 - bitmaps/CVS/.svn/all-wcprops | 23 - bitmaps/CVS/.svn/entries | 130 - bitmaps/CVS/.svn/text-base/Entries.svn-base | 91 - .../CVS/.svn/text-base/Repository.svn-base | 1 - bitmaps/CVS/.svn/text-base/Root.svn-base | 1 - include/.svn/all-wcprops | 113 - include/.svn/entries | 643 -- include/.svn/text-base/bitmap_font.h.svn-base | 37 - include/.svn/text-base/bitmaps.h.svn-base | 21 - include/.svn/text-base/block.h.svn-base | 187 - include/.svn/text-base/block_int.h.svn-base | 104 - include/.svn/text-base/byteorder.h.svn-base | 91 - include/.svn/text-base/glyphname.h.svn-base | 238 - include/.svn/text-base/list.h.svn-base | 600 -- include/.svn/text-base/s3c2410.h.svn-base | 348 - .../.svn/text-base/s3c2410_intc.h.svn-base | 72 - include/.svn/text-base/s3c2410_mmu.h.svn-base | 37 - .../.svn/text-base/s3c2410_power.h.svn-base | 28 - .../.svn/text-base/s3c2410_timer.h.svn-base | 48 - include/.svn/text-base/saturn.h.svn-base | 43 - include/.svn/text-base/symbol.h.svn-base | 68 - include/.svn/text-base/x49gp.h.svn-base | 144 - include/.svn/text-base/x49gp_timer.h.svn-base | 32 - include/.svn/text-base/x49gp_types.h.svn-base | 23 - include/.svn/text-base/x49gp_ui.h.svn-base | 125 - include/CVS/.svn/all-wcprops | 23 - include/CVS/.svn/entries | 130 - include/CVS/.svn/text-base/Entries.svn-base | 18 - .../CVS/.svn/text-base/Repository.svn-base | 1 - include/CVS/.svn/text-base/Root.svn-base | 1 - qemu/.svn/all-wcprops | 23 - qemu/.svn/entries | 139 - qemu/.svn/prop-base/prepare.sh.svn-base | 5 - .../.svn/prop-base/qemu-0.9.0.tar.gz.svn-base | 5 - qemu/.svn/text-base/.cvsignore.svn-base | 1 - qemu/.svn/text-base/prepare.sh.svn-base | 61 - .../.svn/text-base/qemu-0.9.0.tar.gz.svn-base | Bin 1901741 -> 0 bytes qemu/CVS/.svn/all-wcprops | 23 - qemu/CVS/.svn/entries | 130 - qemu/CVS/.svn/text-base/Entries.svn-base | 4 - qemu/CVS/.svn/text-base/Repository.svn-base | 1 - qemu/CVS/.svn/text-base/Root.svn-base | 1 - qemu/patches/.svn/all-wcprops | 161 - qemu/patches/.svn/entries | 915 -- .../text-base/q_block.c_hdled_1.diff.svn-base | 34 - .../q_block_int.h_hdled_1.diff.svn-base | 10 - .../text-base/q_host-cocoa_02.diff.svn-base | 26 - .../.svn/text-base/q_vga.c_02.diff.svn-base | 41 - ...dyngen-check-stack-clobbers.patch.svn-base | 137 - .../qemu-0.7.2-gcc4-opts.patch.svn-base | 37 - .../qemu-0.8.0-gcc4-hacks.patch.svn-base | 118 - .../qemu-0.8.0-osx-bugfix.patch.svn-base | 155 - .../qemu-0.9.0-arm-shift.patch.svn-base | 20 - ...force-16byte-stack-boundary.patch.svn-base | 19 - .../text-base/qemu-0.9.0-gcc4.patch.svn-base | 892 -- .../qemu-0.9.0-i386-FORCE_RET.patch.svn-base | 26 - .../qemu-0.9.0-osx-intel-port.patch.svn-base | 329 - .../text-base/qemu-0.9.0-qcow2.diff.svn-base | 26 - .../qemu-0.9.0-sparc-clobber.patch.svn-base | 10 - ...u-0.9.0-sparc-compile-flags.patch.svn-base | 23 - ...u-0.9.0-sparc-load-store-le.patch.svn-base | 67 - .../qemu-0.9.0-sparc-register.patch.svn-base | 173 - ...-0.9.0-x49gp-arm-dump-state.patch.svn-base | 37 - .../qemu-0.9.0-x49gp-arm-mmu.patch.svn-base | 192 - ...0.9.0-x49gp-arm-semihosting.patch.svn-base | 50 - .../qemu-0.9.0-x49gp-block.patch.svn-base | 1302 --- ...u-0.9.0-x49gp-build-libqemu.patch.svn-base | 15 - ....9.0-x49gp-debug-unassigned.patch.svn-base | 36 - ...-0.9.0-x49gp-phys_ram_dirty.patch.svn-base | 17 - .../qemu-2ndbootdevice_04.diff.svn-base | 165 - qemu/patches/CVS/.svn/all-wcprops | 23 - qemu/patches/CVS/.svn/entries | 130 - .../CVS/.svn/text-base/Entries.svn-base | 27 - .../CVS/.svn/text-base/Repository.svn-base | 1 - qemu/patches/CVS/.svn/text-base/Root.svn-base | 1 - qemu/qemu-git/.svn/all-wcprops | 431 - qemu/qemu-git/.svn/entries | 2457 ----- .../.svn/prop-base/configure-small.svn-base | 5 - .../.svn/prop-base/create_config.svn-base | 5 - .../.svn/text-base/Makefile-small.hw.svn-base | 25 - .../text-base/Makefile-small.objs.svn-base | 32 - .../.svn/text-base/Makefile-small.svn-base | 116 - .../text-base/Makefile-small.target.svn-base | 104 - qemu/qemu-git/.svn/text-base/VERSION.svn-base | 1 - .../.svn/text-base/alpha-dis.c.svn-base | 1917 ---- .../qemu-git/.svn/text-base/alpha.ld.svn-base | 127 - .../.svn/text-base/arm-dis.c.svn-base | 4117 -------- qemu/qemu-git/.svn/text-base/arm.ld.svn-base | 153 - qemu/qemu-git/.svn/text-base/bswap.h.svn-base | 217 - .../.svn/text-base/cache-utils.h.svn-base | 41 - .../qemu-git/.svn/text-base/config.h.svn-base | 2 - .../.svn/text-base/configure-small.svn-base | 1094 -- .../.svn/text-base/cpu-all.h.svn-base | 1076 -- .../.svn/text-base/cpu-common.h.svn-base | 90 - .../.svn/text-base/cpu-defs.h.svn-base | 202 - .../.svn/text-base/cpu-exec.c.svn-base | 1201 --- .../.svn/text-base/create_config.svn-base | 99 - .../.svn/text-base/cris-dis.c.svn-base | 2890 ----- .../qemu-git/.svn/text-base/cutils.c.svn-base | 237 - .../.svn/text-base/def-helper.h.svn-base | 220 - .../.svn/text-base/dis-asm.h.svn-base | 477 - qemu/qemu-git/.svn/text-base/disas.c.svn-base | 416 - qemu/qemu-git/.svn/text-base/disas.h.svn-base | 41 - .../.svn/text-base/dyngen-exec.h.svn-base | 130 - qemu/qemu-git/.svn/text-base/elf.h.svn-base | 1193 --- .../.svn/text-base/exec-all.h.svn-base | 360 - qemu/qemu-git/.svn/text-base/exec.c.svn-base | 3720 ------- .../.svn/text-base/feature_to_c.sh.svn-base | 76 - .../.svn/text-base/gdbstub.h.svn-base | 35 - .../.svn/text-base/gen-icount.h.svn-base | 46 - .../.svn/text-base/host-utils.c.svn-base | 105 - .../.svn/text-base/host-utils.h.svn-base | 236 - .../.svn/text-base/hostregs_helper.h.svn-base | 61 - .../.svn/text-base/hppa-dis.c.svn-base | 2831 ----- qemu/qemu-git/.svn/text-base/hppa.ld.svn-base | 213 - .../.svn/text-base/i386-dis.c.svn-base | 6559 ------------ qemu/qemu-git/.svn/text-base/i386.ld.svn-base | 141 - qemu/qemu-git/.svn/text-base/ia64.ld.svn-base | 209 - .../qemu-git/.svn/text-base/ioport.h.svn-base | 53 - qemu/qemu-git/.svn/text-base/kvm.h.svn-base | 142 - .../.svn/text-base/m68k-dis.c.svn-base | 5045 --------- qemu/qemu-git/.svn/text-base/m68k.ld.svn-base | 175 - .../.svn/text-base/microblaze-dis.c.svn-base | 1102 -- .../.svn/text-base/mips-dis.c.svn-base | 4842 --------- qemu/qemu-git/.svn/text-base/mips.ld.svn-base | 224 - .../qemu-git/.svn/text-base/module.h.svn-base | 38 - qemu/qemu-git/.svn/text-base/osdep.h.svn-base | 108 - .../.svn/text-base/ppc-dis.c.svn-base | 5412 ---------- qemu/qemu-git/.svn/text-base/ppc.ld.svn-base | 227 - .../qemu-git/.svn/text-base/ppc64.ld.svn-base | 220 - .../.svn/text-base/qemu-common.h.svn-base | 275 - .../.svn/text-base/qemu-lock.h.svn-base | 247 - .../.svn/text-base/qemu-log.h.svn-base | 93 - .../.svn/text-base/qemu-malloc.c.svn-base | 102 - .../.svn/text-base/qemu-queue.h.svn-base | 449 - .../.svn/text-base/rules.mak.svn-base | 55 - .../.svn/text-base/s390-dis.c.svn-base | 1704 --- qemu/qemu-git/.svn/text-base/s390.ld.svn-base | 201 - .../.svn/text-base/sh4-dis.c.svn-base | 2083 ---- .../.svn/text-base/softmmu_defs.h.svn-base | 22 - .../.svn/text-base/softmmu_exec.h.svn-base | 134 - .../.svn/text-base/softmmu_header.h.svn-base | 198 - .../text-base/softmmu_template.h.svn-base | 327 - .../.svn/text-base/sparc-dis.c.svn-base | 3253 ------ .../qemu-git/.svn/text-base/sparc.ld.svn-base | 150 - .../.svn/text-base/sparc64.ld.svn-base | 138 - .../.svn/text-base/targphys.h.svn-base | 24 - .../.svn/text-base/tcg-runtime.c.svn-base | 61 - .../.svn/text-base/translate-all.c.svn-base | 194 - .../.svn/text-base/x86_64.ld.svn-base | 170 - .../qemu-git/default-configs/.svn/all-wcprops | 11 - qemu/qemu-git/default-configs/.svn/entries | 62 - .../text-base/arm-softmmu-small.mak.svn-base | 3 - qemu/qemu-git/fpu/.svn/all-wcprops | 41 - qemu/qemu-git/fpu/.svn/entries | 232 - .../text-base/softfloat-macros.h.svn-base | 719 -- .../text-base/softfloat-native.c.svn-base | 534 - .../text-base/softfloat-native.h.svn-base | 499 - .../text-base/softfloat-specialize.h.svn-base | 581 -- .../fpu/.svn/text-base/softfloat.c.svn-base | 5808 ----------- .../fpu/.svn/text-base/softfloat.h.svn-base | 527 - qemu/qemu-git/gdb-xml/.svn/all-wcprops | 29 - qemu/qemu-git/gdb-xml/.svn/entries | 164 - .../.svn/text-base/arm-core.xml.svn-base | 31 - .../.svn/text-base/arm-neon.xml.svn-base | 88 - .../.svn/text-base/arm-vfp.xml.svn-base | 29 - .../.svn/text-base/arm-vfp3.xml.svn-base | 45 - qemu/qemu-git/target-arm/.svn/all-wcprops | 59 - qemu/qemu-git/target-arm/.svn/entries | 334 - .../target-arm/.svn/text-base/cpu.h.svn-base | 457 - .../target-arm/.svn/text-base/exec.h.svn-base | 60 - .../.svn/text-base/helper.c.svn-base | 2598 ----- .../.svn/text-base/helpers.h.svn-base | 450 - .../.svn/text-base/iwmmxt_helper.c.svn-base | 681 -- .../.svn/text-base/neon_helper.c.svn-base | 1459 --- .../.svn/text-base/op_addsub.h.svn-base | 103 - .../.svn/text-base/op_helper.c.svn-base | 489 - .../.svn/text-base/translate.c.svn-base | 9254 ----------------- qemu/qemu-git/tcg/.svn/all-wcprops | 53 - qemu/qemu-git/tcg/.svn/entries | 327 - .../tcg/.svn/text-base/LICENSE.svn-base | 3 - .../tcg/.svn/text-base/README.svn-base | 454 - .../qemu-git/tcg/.svn/text-base/TODO.svn-base | 14 - .../tcg/.svn/text-base/tcg-op.h.svn-base | 2183 ---- .../tcg/.svn/text-base/tcg-opc.h.svn-base | 272 - .../tcg/.svn/text-base/tcg-runtime.h.svn-base | 13 - .../tcg/.svn/text-base/tcg.c.svn-base | 2085 ---- .../tcg/.svn/text-base/tcg.h.svn-base | 468 - qemu/qemu-git/tcg/arm/.svn/all-wcprops | 17 - qemu/qemu-git/tcg/arm/.svn/entries | 96 - .../arm/.svn/text-base/tcg-target.c.svn-base | 1708 --- .../arm/.svn/text-base/tcg-target.h.svn-base | 85 - qemu/qemu-git/tcg/hppa/.svn/all-wcprops | 17 - qemu/qemu-git/tcg/hppa/.svn/entries | 96 - .../hppa/.svn/text-base/tcg-target.c.svn-base | 975 -- .../hppa/.svn/text-base/tcg-target.h.svn-base | 203 - qemu/qemu-git/tcg/i386/.svn/all-wcprops | 17 - qemu/qemu-git/tcg/i386/.svn/entries | 96 - .../i386/.svn/text-base/tcg-target.c.svn-base | 1262 --- .../i386/.svn/text-base/tcg-target.h.svn-base | 67 - qemu/qemu-git/tcg/mips/.svn/all-wcprops | 17 - qemu/qemu-git/tcg/mips/.svn/entries | 96 - .../mips/.svn/text-base/tcg-target.c.svn-base | 1342 --- .../mips/.svn/text-base/tcg-target.h.svn-base | 104 - qemu/qemu-git/tcg/ppc/.svn/all-wcprops | 17 - qemu/qemu-git/tcg/ppc/.svn/entries | 96 - .../ppc/.svn/text-base/tcg-target.c.svn-base | 1615 --- .../ppc/.svn/text-base/tcg-target.h.svn-base | 89 - qemu/qemu-git/tcg/ppc64/.svn/all-wcprops | 17 - qemu/qemu-git/tcg/ppc64/.svn/entries | 96 - .../.svn/text-base/tcg-target.c.svn-base | 1570 --- .../.svn/text-base/tcg-target.h.svn-base | 85 - qemu/qemu-git/tcg/s390/.svn/all-wcprops | 17 - qemu/qemu-git/tcg/s390/.svn/entries | 96 - .../s390/.svn/text-base/tcg-target.c.svn-base | 105 - .../s390/.svn/text-base/tcg-target.h.svn-base | 69 - qemu/qemu-git/tcg/sparc/.svn/all-wcprops | 17 - qemu/qemu-git/tcg/sparc/.svn/entries | 96 - .../.svn/text-base/tcg-target.c.svn-base | 1402 --- .../.svn/text-base/tcg-target.h.svn-base | 129 - qemu/qemu-git/tcg/x86_64/.svn/all-wcprops | 17 - qemu/qemu-git/tcg/x86_64/.svn/entries | 96 - .../.svn/text-base/tcg-target.c.svn-base | 1422 --- .../.svn/text-base/tcg-target.h.svn-base | 91 - sim/.svn/all-wcprops | 11 - sim/.svn/entries | 65 - sim/.svn/text-base/.cvsignore.svn-base | 1 - sim/CVS/.svn/all-wcprops | 23 - sim/CVS/.svn/entries | 130 - sim/CVS/.svn/text-base/Entries.svn-base | 2 - sim/CVS/.svn/text-base/Repository.svn-base | 1 - sim/CVS/.svn/text-base/Root.svn-base | 1 - 325 files changed, 2 insertions(+), 119377 deletions(-) create mode 100644 .gitignore delete mode 100644 bitmaps/.svn/all-wcprops delete mode 100644 bitmaps/.svn/entries delete mode 100644 bitmaps/.svn/text-base/ann_alpha.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/ann_battery.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/ann_busy.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/ann_io.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/ann_left.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/ann_right.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/button_large.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/button_normal.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/button_round.pix.svn-base delete mode 100644 bitmaps/.svn/text-base/button_round.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/button_small.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/button_tiny.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_A.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_B.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_C.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_D.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_E.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_F.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_G.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_H.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_I.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_J.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_K.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_L.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_M.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_N.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_O.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_P.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_Q.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_R.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_S.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_T.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_U.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_V.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_W.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_X.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_Y.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_Z.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny__i.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_ampersand.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_arrowleft.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_arrowright.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_braceleft.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_braceright.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_bracketleft.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_bracketright.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_colon.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_comma.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_equal.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_greater.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_guillemotleft.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_guillemotright.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_hyphen.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_large_comma.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_less.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_math_arrowleft.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_math_arrowright.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_math_downarrowleft.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_math_downarrowright.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_math_e.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_math_equal.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_math_greater.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_math_greaterequal.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_math_infinity.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_math_integral.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_math_less.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_math_lessequal.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_math_notequal.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_math_numbersign.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_math_partialdiff.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_math_pi.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_math_radical.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_math_summation.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_math_x.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_math_y.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_notdef.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_numbersign.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_one.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_overscore.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_parenleft.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_parenright.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_period.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_quotedbl.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_slash.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_three.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_two.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_twosuperior.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_underscore.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_xsuperior.xbm.svn-base delete mode 100644 bitmaps/.svn/text-base/tiny_zero.xbm.svn-base delete mode 100644 bitmaps/CVS/.svn/all-wcprops delete mode 100644 bitmaps/CVS/.svn/entries delete mode 100644 bitmaps/CVS/.svn/text-base/Entries.svn-base delete mode 100644 bitmaps/CVS/.svn/text-base/Repository.svn-base delete mode 100644 bitmaps/CVS/.svn/text-base/Root.svn-base delete mode 100644 include/.svn/all-wcprops delete mode 100644 include/.svn/entries delete mode 100644 include/.svn/text-base/bitmap_font.h.svn-base delete mode 100644 include/.svn/text-base/bitmaps.h.svn-base delete mode 100644 include/.svn/text-base/block.h.svn-base delete mode 100644 include/.svn/text-base/block_int.h.svn-base delete mode 100644 include/.svn/text-base/byteorder.h.svn-base delete mode 100644 include/.svn/text-base/glyphname.h.svn-base delete mode 100644 include/.svn/text-base/list.h.svn-base delete mode 100644 include/.svn/text-base/s3c2410.h.svn-base delete mode 100644 include/.svn/text-base/s3c2410_intc.h.svn-base delete mode 100644 include/.svn/text-base/s3c2410_mmu.h.svn-base delete mode 100644 include/.svn/text-base/s3c2410_power.h.svn-base delete mode 100644 include/.svn/text-base/s3c2410_timer.h.svn-base delete mode 100644 include/.svn/text-base/saturn.h.svn-base delete mode 100644 include/.svn/text-base/symbol.h.svn-base delete mode 100644 include/.svn/text-base/x49gp.h.svn-base delete mode 100644 include/.svn/text-base/x49gp_timer.h.svn-base delete mode 100644 include/.svn/text-base/x49gp_types.h.svn-base delete mode 100644 include/.svn/text-base/x49gp_ui.h.svn-base delete mode 100644 include/CVS/.svn/all-wcprops delete mode 100644 include/CVS/.svn/entries delete mode 100644 include/CVS/.svn/text-base/Entries.svn-base delete mode 100644 include/CVS/.svn/text-base/Repository.svn-base delete mode 100644 include/CVS/.svn/text-base/Root.svn-base delete mode 100644 qemu/.svn/all-wcprops delete mode 100644 qemu/.svn/entries delete mode 100644 qemu/.svn/prop-base/prepare.sh.svn-base delete mode 100644 qemu/.svn/prop-base/qemu-0.9.0.tar.gz.svn-base delete mode 100644 qemu/.svn/text-base/.cvsignore.svn-base delete mode 100644 qemu/.svn/text-base/prepare.sh.svn-base delete mode 100644 qemu/.svn/text-base/qemu-0.9.0.tar.gz.svn-base delete mode 100644 qemu/CVS/.svn/all-wcprops delete mode 100644 qemu/CVS/.svn/entries delete mode 100644 qemu/CVS/.svn/text-base/Entries.svn-base delete mode 100644 qemu/CVS/.svn/text-base/Repository.svn-base delete mode 100644 qemu/CVS/.svn/text-base/Root.svn-base delete mode 100644 qemu/patches/.svn/all-wcprops delete mode 100644 qemu/patches/.svn/entries delete mode 100644 qemu/patches/.svn/text-base/q_block.c_hdled_1.diff.svn-base delete mode 100644 qemu/patches/.svn/text-base/q_block_int.h_hdled_1.diff.svn-base delete mode 100644 qemu/patches/.svn/text-base/q_host-cocoa_02.diff.svn-base delete mode 100644 qemu/patches/.svn/text-base/q_vga.c_02.diff.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-0.7.2-dyngen-check-stack-clobbers.patch.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-0.7.2-gcc4-opts.patch.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-0.8.0-gcc4-hacks.patch.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-0.8.0-osx-bugfix.patch.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-0.9.0-arm-shift.patch.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-0.9.0-enforce-16byte-stack-boundary.patch.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-0.9.0-gcc4.patch.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-0.9.0-i386-FORCE_RET.patch.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-0.9.0-osx-intel-port.patch.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-0.9.0-qcow2.diff.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-0.9.0-sparc-clobber.patch.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-0.9.0-sparc-compile-flags.patch.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-0.9.0-sparc-load-store-le.patch.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-0.9.0-sparc-register.patch.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-0.9.0-x49gp-arm-dump-state.patch.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-0.9.0-x49gp-arm-mmu.patch.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-0.9.0-x49gp-arm-semihosting.patch.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-0.9.0-x49gp-block.patch.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-0.9.0-x49gp-build-libqemu.patch.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-0.9.0-x49gp-debug-unassigned.patch.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-0.9.0-x49gp-phys_ram_dirty.patch.svn-base delete mode 100644 qemu/patches/.svn/text-base/qemu-2ndbootdevice_04.diff.svn-base delete mode 100644 qemu/patches/CVS/.svn/all-wcprops delete mode 100644 qemu/patches/CVS/.svn/entries delete mode 100644 qemu/patches/CVS/.svn/text-base/Entries.svn-base delete mode 100644 qemu/patches/CVS/.svn/text-base/Repository.svn-base delete mode 100644 qemu/patches/CVS/.svn/text-base/Root.svn-base delete mode 100644 qemu/qemu-git/.svn/all-wcprops delete mode 100644 qemu/qemu-git/.svn/entries delete mode 100644 qemu/qemu-git/.svn/prop-base/configure-small.svn-base delete mode 100644 qemu/qemu-git/.svn/prop-base/create_config.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/Makefile-small.hw.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/Makefile-small.objs.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/Makefile-small.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/Makefile-small.target.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/VERSION.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/alpha-dis.c.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/alpha.ld.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/arm-dis.c.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/arm.ld.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/bswap.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/cache-utils.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/config.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/configure-small.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/cpu-all.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/cpu-common.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/cpu-defs.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/cpu-exec.c.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/create_config.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/cris-dis.c.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/cutils.c.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/def-helper.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/dis-asm.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/disas.c.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/disas.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/dyngen-exec.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/elf.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/exec-all.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/exec.c.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/feature_to_c.sh.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/gdbstub.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/gen-icount.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/host-utils.c.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/host-utils.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/hostregs_helper.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/hppa-dis.c.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/hppa.ld.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/i386-dis.c.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/i386.ld.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/ia64.ld.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/ioport.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/kvm.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/m68k-dis.c.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/m68k.ld.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/microblaze-dis.c.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/mips-dis.c.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/mips.ld.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/module.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/osdep.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/ppc-dis.c.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/ppc.ld.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/ppc64.ld.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/qemu-common.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/qemu-lock.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/qemu-log.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/qemu-malloc.c.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/qemu-queue.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/rules.mak.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/s390-dis.c.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/s390.ld.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/sh4-dis.c.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/softmmu_defs.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/softmmu_exec.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/softmmu_header.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/softmmu_template.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/sparc-dis.c.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/sparc.ld.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/sparc64.ld.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/targphys.h.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/tcg-runtime.c.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/translate-all.c.svn-base delete mode 100644 qemu/qemu-git/.svn/text-base/x86_64.ld.svn-base delete mode 100644 qemu/qemu-git/default-configs/.svn/all-wcprops delete mode 100644 qemu/qemu-git/default-configs/.svn/entries delete mode 100644 qemu/qemu-git/default-configs/.svn/text-base/arm-softmmu-small.mak.svn-base delete mode 100644 qemu/qemu-git/fpu/.svn/all-wcprops delete mode 100644 qemu/qemu-git/fpu/.svn/entries delete mode 100644 qemu/qemu-git/fpu/.svn/text-base/softfloat-macros.h.svn-base delete mode 100644 qemu/qemu-git/fpu/.svn/text-base/softfloat-native.c.svn-base delete mode 100644 qemu/qemu-git/fpu/.svn/text-base/softfloat-native.h.svn-base delete mode 100644 qemu/qemu-git/fpu/.svn/text-base/softfloat-specialize.h.svn-base delete mode 100644 qemu/qemu-git/fpu/.svn/text-base/softfloat.c.svn-base delete mode 100644 qemu/qemu-git/fpu/.svn/text-base/softfloat.h.svn-base delete mode 100644 qemu/qemu-git/gdb-xml/.svn/all-wcprops delete mode 100644 qemu/qemu-git/gdb-xml/.svn/entries delete mode 100644 qemu/qemu-git/gdb-xml/.svn/text-base/arm-core.xml.svn-base delete mode 100644 qemu/qemu-git/gdb-xml/.svn/text-base/arm-neon.xml.svn-base delete mode 100644 qemu/qemu-git/gdb-xml/.svn/text-base/arm-vfp.xml.svn-base delete mode 100644 qemu/qemu-git/gdb-xml/.svn/text-base/arm-vfp3.xml.svn-base delete mode 100644 qemu/qemu-git/target-arm/.svn/all-wcprops delete mode 100644 qemu/qemu-git/target-arm/.svn/entries delete mode 100644 qemu/qemu-git/target-arm/.svn/text-base/cpu.h.svn-base delete mode 100644 qemu/qemu-git/target-arm/.svn/text-base/exec.h.svn-base delete mode 100644 qemu/qemu-git/target-arm/.svn/text-base/helper.c.svn-base delete mode 100644 qemu/qemu-git/target-arm/.svn/text-base/helpers.h.svn-base delete mode 100644 qemu/qemu-git/target-arm/.svn/text-base/iwmmxt_helper.c.svn-base delete mode 100644 qemu/qemu-git/target-arm/.svn/text-base/neon_helper.c.svn-base delete mode 100644 qemu/qemu-git/target-arm/.svn/text-base/op_addsub.h.svn-base delete mode 100644 qemu/qemu-git/target-arm/.svn/text-base/op_helper.c.svn-base delete mode 100644 qemu/qemu-git/target-arm/.svn/text-base/translate.c.svn-base delete mode 100644 qemu/qemu-git/tcg/.svn/all-wcprops delete mode 100644 qemu/qemu-git/tcg/.svn/entries delete mode 100644 qemu/qemu-git/tcg/.svn/text-base/LICENSE.svn-base delete mode 100644 qemu/qemu-git/tcg/.svn/text-base/README.svn-base delete mode 100644 qemu/qemu-git/tcg/.svn/text-base/TODO.svn-base delete mode 100644 qemu/qemu-git/tcg/.svn/text-base/tcg-op.h.svn-base delete mode 100644 qemu/qemu-git/tcg/.svn/text-base/tcg-opc.h.svn-base delete mode 100644 qemu/qemu-git/tcg/.svn/text-base/tcg-runtime.h.svn-base delete mode 100644 qemu/qemu-git/tcg/.svn/text-base/tcg.c.svn-base delete mode 100644 qemu/qemu-git/tcg/.svn/text-base/tcg.h.svn-base delete mode 100644 qemu/qemu-git/tcg/arm/.svn/all-wcprops delete mode 100644 qemu/qemu-git/tcg/arm/.svn/entries delete mode 100644 qemu/qemu-git/tcg/arm/.svn/text-base/tcg-target.c.svn-base delete mode 100644 qemu/qemu-git/tcg/arm/.svn/text-base/tcg-target.h.svn-base delete mode 100644 qemu/qemu-git/tcg/hppa/.svn/all-wcprops delete mode 100644 qemu/qemu-git/tcg/hppa/.svn/entries delete mode 100644 qemu/qemu-git/tcg/hppa/.svn/text-base/tcg-target.c.svn-base delete mode 100644 qemu/qemu-git/tcg/hppa/.svn/text-base/tcg-target.h.svn-base delete mode 100644 qemu/qemu-git/tcg/i386/.svn/all-wcprops delete mode 100644 qemu/qemu-git/tcg/i386/.svn/entries delete mode 100644 qemu/qemu-git/tcg/i386/.svn/text-base/tcg-target.c.svn-base delete mode 100644 qemu/qemu-git/tcg/i386/.svn/text-base/tcg-target.h.svn-base delete mode 100644 qemu/qemu-git/tcg/mips/.svn/all-wcprops delete mode 100644 qemu/qemu-git/tcg/mips/.svn/entries delete mode 100644 qemu/qemu-git/tcg/mips/.svn/text-base/tcg-target.c.svn-base delete mode 100644 qemu/qemu-git/tcg/mips/.svn/text-base/tcg-target.h.svn-base delete mode 100644 qemu/qemu-git/tcg/ppc/.svn/all-wcprops delete mode 100644 qemu/qemu-git/tcg/ppc/.svn/entries delete mode 100644 qemu/qemu-git/tcg/ppc/.svn/text-base/tcg-target.c.svn-base delete mode 100644 qemu/qemu-git/tcg/ppc/.svn/text-base/tcg-target.h.svn-base delete mode 100644 qemu/qemu-git/tcg/ppc64/.svn/all-wcprops delete mode 100644 qemu/qemu-git/tcg/ppc64/.svn/entries delete mode 100644 qemu/qemu-git/tcg/ppc64/.svn/text-base/tcg-target.c.svn-base delete mode 100644 qemu/qemu-git/tcg/ppc64/.svn/text-base/tcg-target.h.svn-base delete mode 100644 qemu/qemu-git/tcg/s390/.svn/all-wcprops delete mode 100644 qemu/qemu-git/tcg/s390/.svn/entries delete mode 100644 qemu/qemu-git/tcg/s390/.svn/text-base/tcg-target.c.svn-base delete mode 100644 qemu/qemu-git/tcg/s390/.svn/text-base/tcg-target.h.svn-base delete mode 100644 qemu/qemu-git/tcg/sparc/.svn/all-wcprops delete mode 100644 qemu/qemu-git/tcg/sparc/.svn/entries delete mode 100644 qemu/qemu-git/tcg/sparc/.svn/text-base/tcg-target.c.svn-base delete mode 100644 qemu/qemu-git/tcg/sparc/.svn/text-base/tcg-target.h.svn-base delete mode 100644 qemu/qemu-git/tcg/x86_64/.svn/all-wcprops delete mode 100644 qemu/qemu-git/tcg/x86_64/.svn/entries delete mode 100644 qemu/qemu-git/tcg/x86_64/.svn/text-base/tcg-target.c.svn-base delete mode 100644 qemu/qemu-git/tcg/x86_64/.svn/text-base/tcg-target.h.svn-base delete mode 100644 sim/.svn/all-wcprops delete mode 100644 sim/.svn/entries delete mode 100644 sim/.svn/text-base/.cvsignore.svn-base delete mode 100644 sim/CVS/.svn/all-wcprops delete mode 100644 sim/CVS/.svn/entries delete mode 100644 sim/CVS/.svn/text-base/Entries.svn-base delete mode 100644 sim/CVS/.svn/text-base/Repository.svn-base delete mode 100644 sim/CVS/.svn/text-base/Root.svn-base diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..1592097 --- /dev/null +++ b/.gitignore @@ -0,0 +1,2 @@ +sim/CVS* +*.svn/* \ No newline at end of file diff --git a/bitmaps/.svn/all-wcprops b/bitmaps/.svn/all-wcprops deleted file mode 100644 index 91fd5b6..0000000 --- a/bitmaps/.svn/all-wcprops +++ /dev/null @@ -1,545 +0,0 @@ -K 25 -svn:wc:ra_dav:version-url -V 32 -/p/x49gp/code/!svn/ver/1/bitmaps -END -tiny_braceleft.xbm -K 25 -svn:wc:ra_dav:version-url -V 51 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_braceleft.xbm -END -tiny__i.xbm -K 25 -svn:wc:ra_dav:version-url -V 44 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny__i.xbm -END -tiny_hyphen.xbm -K 25 -svn:wc:ra_dav:version-url -V 48 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_hyphen.xbm -END -tiny_comma.xbm -K 25 -svn:wc:ra_dav:version-url -V 47 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_comma.xbm -END -tiny_math_notequal.xbm -K 25 -svn:wc:ra_dav:version-url -V 55 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_math_notequal.xbm -END -tiny_large_comma.xbm -K 25 -svn:wc:ra_dav:version-url -V 53 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_large_comma.xbm -END -tiny_math_radical.xbm -K 25 -svn:wc:ra_dav:version-url -V 54 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_math_radical.xbm -END -tiny_numbersign.xbm -K 25 -svn:wc:ra_dav:version-url -V 52 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_numbersign.xbm -END -tiny_colon.xbm -K 25 -svn:wc:ra_dav:version-url -V 47 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_colon.xbm -END -tiny_braceright.xbm -K 25 -svn:wc:ra_dav:version-url -V 52 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_braceright.xbm -END -tiny_guillemotleft.xbm -K 25 -svn:wc:ra_dav:version-url -V 55 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_guillemotleft.xbm -END -tiny_quotedbl.xbm -K 25 -svn:wc:ra_dav:version-url -V 50 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_quotedbl.xbm -END -tiny_zero.xbm -K 25 -svn:wc:ra_dav:version-url -V 46 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_zero.xbm -END -tiny_math_numbersign.xbm -K 25 -svn:wc:ra_dav:version-url -V 57 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_math_numbersign.xbm -END -tiny_math_summation.xbm -K 25 -svn:wc:ra_dav:version-url -V 56 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_math_summation.xbm -END -tiny_math_downarrowright.xbm -K 25 -svn:wc:ra_dav:version-url -V 61 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_math_downarrowright.xbm -END -tiny_greater.xbm -K 25 -svn:wc:ra_dav:version-url -V 49 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_greater.xbm -END -button_round.pix -K 25 -svn:wc:ra_dav:version-url -V 49 -/p/x49gp/code/!svn/ver/1/bitmaps/button_round.pix -END -button_small.xbm -K 25 -svn:wc:ra_dav:version-url -V 49 -/p/x49gp/code/!svn/ver/1/bitmaps/button_small.xbm -END -ann_io.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/ann_io.xbm -END -tiny_xsuperior.xbm -K 25 -svn:wc:ra_dav:version-url -V 51 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_xsuperior.xbm -END -tiny_twosuperior.xbm -K 25 -svn:wc:ra_dav:version-url -V 53 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_twosuperior.xbm -END -tiny_math_downarrowleft.xbm -K 25 -svn:wc:ra_dav:version-url -V 60 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_math_downarrowleft.xbm -END -tiny_overscore.xbm -K 25 -svn:wc:ra_dav:version-url -V 51 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_overscore.xbm -END -tiny_three.xbm -K 25 -svn:wc:ra_dav:version-url -V 47 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_three.xbm -END -tiny_slash.xbm -K 25 -svn:wc:ra_dav:version-url -V 47 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_slash.xbm -END -ann_alpha.xbm -K 25 -svn:wc:ra_dav:version-url -V 46 -/p/x49gp/code/!svn/ver/1/bitmaps/ann_alpha.xbm -END -button_round.xbm -K 25 -svn:wc:ra_dav:version-url -V 49 -/p/x49gp/code/!svn/ver/1/bitmaps/button_round.xbm -END -tiny_math_less.xbm -K 25 -svn:wc:ra_dav:version-url -V 51 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_math_less.xbm -END -tiny_notdef.xbm -K 25 -svn:wc:ra_dav:version-url -V 48 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_notdef.xbm -END -tiny_A.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_A.xbm -END -tiny_math_equal.xbm -K 25 -svn:wc:ra_dav:version-url -V 52 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_math_equal.xbm -END -tiny_parenleft.xbm -K 25 -svn:wc:ra_dav:version-url -V 51 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_parenleft.xbm -END -button_normal.xbm -K 25 -svn:wc:ra_dav:version-url -V 50 -/p/x49gp/code/!svn/ver/1/bitmaps/button_normal.xbm -END -tiny_B.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_B.xbm -END -tiny_math_pi.xbm -K 25 -svn:wc:ra_dav:version-url -V 49 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_math_pi.xbm -END -tiny_C.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_C.xbm -END -button_large.xbm -K 25 -svn:wc:ra_dav:version-url -V 49 -/p/x49gp/code/!svn/ver/1/bitmaps/button_large.xbm -END -tiny_period.xbm -K 25 -svn:wc:ra_dav:version-url -V 48 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_period.xbm -END -tiny_D.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_D.xbm -END -tiny_E.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_E.xbm -END -tiny_F.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_F.xbm -END -tiny_G.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_G.xbm -END -tiny_H.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_H.xbm -END -tiny_arrowright.xbm -K 25 -svn:wc:ra_dav:version-url -V 52 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_arrowright.xbm -END -tiny_I.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_I.xbm -END -tiny_J.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_J.xbm -END -tiny_K.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_K.xbm -END -tiny_L.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_L.xbm -END -tiny_M.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_M.xbm -END -tiny_math_e.xbm -K 25 -svn:wc:ra_dav:version-url -V 48 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_math_e.xbm -END -tiny_N.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_N.xbm -END -tiny_O.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_O.xbm -END -tiny_guillemotright.xbm -K 25 -svn:wc:ra_dav:version-url -V 56 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_guillemotright.xbm -END -tiny_P.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_P.xbm -END -tiny_Q.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_Q.xbm -END -tiny_math_arrowright.xbm -K 25 -svn:wc:ra_dav:version-url -V 57 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_math_arrowright.xbm -END -tiny_R.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_R.xbm -END -tiny_math_greater.xbm -K 25 -svn:wc:ra_dav:version-url -V 54 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_math_greater.xbm -END -tiny_S.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_S.xbm -END -tiny_T.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_T.xbm -END -ann_battery.xbm -K 25 -svn:wc:ra_dav:version-url -V 48 -/p/x49gp/code/!svn/ver/1/bitmaps/ann_battery.xbm -END -tiny_U.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_U.xbm -END -tiny_V.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_V.xbm -END -tiny_W.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_W.xbm -END -tiny_equal.xbm -K 25 -svn:wc:ra_dav:version-url -V 47 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_equal.xbm -END -tiny_X.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_X.xbm -END -tiny_Y.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_Y.xbm -END -tiny_Z.xbm -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_Z.xbm -END -tiny_underscore.xbm -K 25 -svn:wc:ra_dav:version-url -V 52 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_underscore.xbm -END -tiny_ampersand.xbm -K 25 -svn:wc:ra_dav:version-url -V 51 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_ampersand.xbm -END -button_tiny.xbm -K 25 -svn:wc:ra_dav:version-url -V 48 -/p/x49gp/code/!svn/ver/1/bitmaps/button_tiny.xbm -END -ann_busy.xbm -K 25 -svn:wc:ra_dav:version-url -V 45 -/p/x49gp/code/!svn/ver/1/bitmaps/ann_busy.xbm -END -tiny_math_arrowleft.xbm -K 25 -svn:wc:ra_dav:version-url -V 56 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_math_arrowleft.xbm -END -tiny_math_integral.xbm -K 25 -svn:wc:ra_dav:version-url -V 55 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_math_integral.xbm -END -tiny_math_x.xbm -K 25 -svn:wc:ra_dav:version-url -V 48 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_math_x.xbm -END -tiny_math_y.xbm -K 25 -svn:wc:ra_dav:version-url -V 48 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_math_y.xbm -END -ann_left.xbm -K 25 -svn:wc:ra_dav:version-url -V 45 -/p/x49gp/code/!svn/ver/1/bitmaps/ann_left.xbm -END -tiny_math_greaterequal.xbm -K 25 -svn:wc:ra_dav:version-url -V 59 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_math_greaterequal.xbm -END -tiny_math_partialdiff.xbm -K 25 -svn:wc:ra_dav:version-url -V 58 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_math_partialdiff.xbm -END -tiny_math_infinity.xbm -K 25 -svn:wc:ra_dav:version-url -V 55 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_math_infinity.xbm -END -tiny_parenright.xbm -K 25 -svn:wc:ra_dav:version-url -V 52 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_parenright.xbm -END -tiny_arrowleft.xbm -K 25 -svn:wc:ra_dav:version-url -V 51 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_arrowleft.xbm -END -tiny_less.xbm -K 25 -svn:wc:ra_dav:version-url -V 46 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_less.xbm -END -ann_right.xbm -K 25 -svn:wc:ra_dav:version-url -V 46 -/p/x49gp/code/!svn/ver/1/bitmaps/ann_right.xbm -END -tiny_math_lessequal.xbm -K 25 -svn:wc:ra_dav:version-url -V 56 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_math_lessequal.xbm -END -tiny_bracketright.xbm -K 25 -svn:wc:ra_dav:version-url -V 54 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_bracketright.xbm -END -tiny_two.xbm -K 25 -svn:wc:ra_dav:version-url -V 45 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_two.xbm -END -tiny_one.xbm -K 25 -svn:wc:ra_dav:version-url -V 45 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_one.xbm -END -tiny_bracketleft.xbm -K 25 -svn:wc:ra_dav:version-url -V 53 -/p/x49gp/code/!svn/ver/1/bitmaps/tiny_bracketleft.xbm -END diff --git a/bitmaps/.svn/entries b/bitmaps/.svn/entries deleted file mode 100644 index a45961b..0000000 --- a/bitmaps/.svn/entries +++ /dev/null @@ -1,3091 +0,0 @@ -10 - -dir -11 -http://svn.code.sf.net/p/x49gp/code/bitmaps -http://svn.code.sf.net/p/x49gp/code - - - -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - -481df3bd-3408-496c-b7de-451e46197bb5 - -tiny_braceleft.xbm -file - - - - -2013-08-23T00:54:47.000000Z -6a96ca03ae4d3131ae52b9ec2a8df2c1 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -230 - -tiny__i.xbm -file - - - - -2013-08-23T00:54:47.000000Z -e45172ee6d333e4d51d3a3952dcc9456 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_hyphen.xbm -file - - - - -2013-08-23T00:54:47.000000Z -02b721c95ca75c341d95fcbb796a6e4c -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -185 - -tiny_comma.xbm -file - - - - -2013-08-23T00:54:47.000000Z -427fb7c5c7f62bb831d531023236b266 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -174 - -tiny_math_notequal.xbm -file - - - - -2013-08-23T00:54:47.000000Z -7c6f9077263882d4c7d3f639e28ac981 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -244 - -tiny_large_comma.xbm -file - - - - -2013-08-23T00:54:47.000000Z -f9c5465b96c7f134416587673b0fe580 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -221 - -tiny_math_radical.xbm -file - - - - -2013-08-23T00:54:47.000000Z -e6bc9c176bf8289c8a2a160c20c20dfe -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -258 - -tiny_numbersign.xbm -file - - - - -2013-08-23T00:54:47.000000Z -a3110308b1ebef44c8facd04915ec313 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -217 - -tiny_colon.xbm -file - - - - -2013-08-23T00:54:47.000000Z -bd62ab99812302fa0bf412cb33e31c9f -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -191 - -tiny_braceright.xbm -file - - - - -2013-08-23T00:54:47.000000Z -2a70fe7d34d3b1705c1c550d5e7097be -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -235 - -tiny_guillemotleft.xbm -file - - - - -2013-08-23T00:54:47.000000Z -250bf68b6a3ba4d65843c8a093dbbdcc -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -269 - -tiny_quotedbl.xbm -file - - - - -2013-08-23T00:54:47.000000Z -0e9aed0029bebe338cd135b0cc9015e3 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -213 - -tiny_zero.xbm -file - - - - -2013-08-23T00:54:47.000000Z -05dddea7641296e8fe9c68839f4333bf -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -193 - -tiny_math_numbersign.xbm -file - - - - -2013-08-23T00:54:47.000000Z -a0a8c518a2d57279b1d26339e1882b83 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -306 - -tiny_math_summation.xbm -file - - - - -2013-08-23T00:54:47.000000Z -5174f3a9d0384d92876c174101b6dcc4 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -255 - -tiny_math_downarrowright.xbm -file - - - - -2013-08-23T00:54:47.000000Z -9f2b6bea47636d415a09e8e822796b83 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -323 - -tiny_greater.xbm -file - - - - -2013-08-23T00:54:47.000000Z -c25726fc89e3fb76af461f8915c429b4 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -208 - -button_round.pix -file - - - - -2013-08-23T00:54:47.000000Z -f15f0737c0a09735505fce818dbb11bb -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -10070 - -button_small.xbm -file - - - - -2013-08-23T00:54:47.000000Z -4c26a830d99646aa716fee86b517d6f5 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -983 - -ann_io.xbm -file - - - - -2013-08-23T00:54:47.000000Z -b24a7a59cb19b584bdbfac87d01d76a8 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -239 - -tiny_xsuperior.xbm -file - - - - -2013-08-23T00:54:47.000000Z -609f8d464b3ed9316aec849c808cde01 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -230 - -tiny_twosuperior.xbm -file - - - - -2013-08-23T00:54:47.000000Z -fd65cd07c1144c654a97a23efd4f7a76 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -240 - -tiny_math_downarrowleft.xbm -file - - - - -2013-08-23T00:54:47.000000Z -cd8a369fbf3d1deda3eaf7d99b2d76ce -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -318 - -tiny_overscore.xbm -file - - - - -2013-08-23T00:54:47.000000Z -e9c53c81284ecfa8adb417e0c4d141b7 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -230 - -tiny_three.xbm -file - - - - -2013-08-23T00:54:47.000000Z -c7ae04ce1e55c19e2e1b54a1f4fdc942 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -198 - -tiny_slash.xbm -file - - - - -2013-08-23T00:54:47.000000Z -86d8e5949fb643f6ab346e52cb07f9db -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -198 - -ann_alpha.xbm -file - - - - -2013-08-23T00:54:47.000000Z -a69e91c81fb2cf254290833e5b25facc -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -248 - -button_round.xbm -file - - - - -2013-08-23T00:54:47.000000Z -6518ef3935067e1f6a29da6d36f7ebd7 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -1139 - -tiny_math_less.xbm -file - - - - -2013-08-23T00:54:47.000000Z -8935056ad75a52e9f7ecf626d199ffc1 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -218 - -tiny_notdef.xbm -file - - - - -2013-08-23T00:54:47.000000Z -f8ddf3eea89729fbdf557b9e16ef1044 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -191 - -tiny_A.xbm -file - - - - -2013-08-23T00:54:47.000000Z -d115248bf9d36052d64e8952238d83f3 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_math_equal.xbm -file - - - - -2013-08-23T00:54:47.000000Z -7e20ed3eaf621d49c87da739d4824d8a -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -217 - -button_normal.xbm -file - - - - -2013-08-23T00:54:47.000000Z -c64b706e97d20ef524a024a49c03d966 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -1160 - -tiny_parenleft.xbm -file - - - - -2013-08-23T00:54:47.000000Z -bb48568441a7b0d9e69874a885bf537a -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -230 - -tiny_B.xbm -file - - - - -2013-08-23T00:54:47.000000Z -71bd5b0ecad09a679c3a8d3fccdc05f6 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_math_pi.xbm -file - - - - -2013-08-23T00:54:47.000000Z -7c9e701a58a036fa12cab9a591b84fd6 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -238 - -tiny_C.xbm -file - - - - -2013-08-23T00:54:47.000000Z -aaf99e9138ecc75faedfadd60d98226c -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -button_large.xbm -file - - - - -2013-08-23T00:54:47.000000Z -b201374266ab1b3fe5b6595ff92d01da -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -1307 - -tiny_period.xbm -file - - - - -2013-08-23T00:54:47.000000Z -c765fa4ea7a16850aba7935fbc11118a -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -173 - -tiny_D.xbm -file - - - - -2013-08-23T00:54:47.000000Z -ce07d0dc51abdea43eb72f3b7085ceea -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_E.xbm -file - - - - -2013-08-23T00:54:47.000000Z -26e0735e3b882e183a27963793cd4140 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_F.xbm -file - - - - -2013-08-23T00:54:47.000000Z -4961173732dc639e4c082eb068227541 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_G.xbm -file - - - - -2013-08-23T00:54:47.000000Z -81572038798aa20853ae863dd95c54e9 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_H.xbm -file - - - - -2013-08-23T00:54:47.000000Z -2b4113578593f6d7c28a328b8a0611e4 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_arrowright.xbm -file - - - - -2013-08-23T00:54:47.000000Z -77a9645449129d773a378b26429f0e3b -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -210 - -tiny_I.xbm -file - - - - -2013-08-23T00:54:47.000000Z -1de086b1f2322748816e03937933423b -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_J.xbm -file - - - - -2013-08-23T00:54:47.000000Z -ed255186f2eefde7b621cf7e9f0b2299 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_K.xbm -file - - - - -2013-08-23T00:54:47.000000Z -a65402d6bed8531560cf33b70cd92e22 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_L.xbm -file - - - - -2013-08-23T00:54:47.000000Z -3b628d5abd97e8cb7a9f960b509bc601 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_M.xbm -file - - - - -2013-08-23T00:54:47.000000Z -aac0dc403d21ccbc230d153523506ff5 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_math_e.xbm -file - - - - -2013-08-23T00:54:47.000000Z -aec00d703dbc898019a71f724a4546af -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -197 - -tiny_N.xbm -file - - - - -2013-08-23T00:54:47.000000Z -f110f872da1081193af100a0bb248229 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_O.xbm -file - - - - -2013-08-23T00:54:47.000000Z -7348b768df5cedc854c561a9ce12de69 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_guillemotright.xbm -file - - - - -2013-08-23T00:54:47.000000Z -68a9cf18f73ec3a14abc7cc7c466764f -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -274 - -tiny_P.xbm -file - - - - -2013-08-23T00:54:47.000000Z -a9789b1b6f5e43ab1bfb6607f29f11e8 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_Q.xbm -file - - - - -2013-08-23T00:54:47.000000Z -ee8b504d1969c72096ae64719397c3d8 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_math_arrowright.xbm -file - - - - -2013-08-23T00:54:47.000000Z -d9d647b0b038378ce4a9dd97d468e7c7 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -279 - -tiny_R.xbm -file - - - - -2013-08-23T00:54:47.000000Z -224a2bb0fb66ea7963beb3afa8405a50 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_math_greater.xbm -file - - - - -2013-08-23T00:54:47.000000Z -47acdca9158d3cf5e04cf4202fead77f -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -233 - -tiny_S.xbm -file - - - - -2013-08-23T00:54:47.000000Z -10307996f827bd06a19345c4d2074dc4 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_T.xbm -file - - - - -2013-08-23T00:54:47.000000Z -e23a0eb281304a2e457c151cb3397af7 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -ann_battery.xbm -file - - - - -2013-08-23T00:54:47.000000Z -917cf2439a9f9d878b6d5eedc40aad13 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -254 - -tiny_U.xbm -file - - - - -2013-08-23T00:54:47.000000Z -ffc96f4ed1390dd3c736a04b6a62be62 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_V.xbm -file - - - - -2013-08-23T00:54:47.000000Z -304163b43679e4dfc5df7fc9293285bc -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_W.xbm -file - - - - -2013-08-23T00:54:47.000000Z -25c909c38cfdb595e1ce2ea2bd307efc -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_equal.xbm -file - - - - -2013-08-23T00:54:47.000000Z -d57654dc8b7338e3bfa24239a10951c1 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -186 - -tiny_X.xbm -file - - - - -2013-08-23T00:54:47.000000Z -ba7244aa01ff8b65616236adedd5f491 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_Y.xbm -file - - - - -2013-08-23T00:54:47.000000Z -4775998ea1125793b35a6bb2e109b3b4 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_Z.xbm -file - - - - -2013-08-23T00:54:47.000000Z -eb7ace0d75d226e0f37eb2f04821724d -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -178 - -tiny_underscore.xbm -file - - - - -2013-08-23T00:54:47.000000Z -e8936ec5f80e2e66bd33180c82ce26ae -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -199 - -tiny_ampersand.xbm -file - - - - -2013-08-23T00:54:47.000000Z -161d44f473663d54602232e99d35f2f6 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -218 - -button_tiny.xbm -file - - - - -2013-08-23T00:54:47.000000Z -2eab65dd0f188474e4f4e3602ad506cc -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -794 - -ann_busy.xbm -file - - - - -2013-08-23T00:54:47.000000Z -eb8778604ac87bb01780633e4162cbda -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -245 - -tiny_math_arrowleft.xbm -file - - - - -2013-08-23T00:54:47.000000Z -feeb8b82ea001df3a98de1f16c130c2d -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -274 - -tiny_math_integral.xbm -file - - - - -2013-08-23T00:54:47.000000Z -a5be082029e753d65b85798c82d11bc4 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -320 - -tiny_math_x.xbm -file - - - - -2013-08-23T00:54:47.000000Z -4e37ae052a1ae3ae3f3394a9924925d0 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -197 - -tiny_math_y.xbm -file - - - - -2013-08-23T00:54:47.000000Z -90f36c96ecc01f2c7fd2cbea59c2cd4a -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -215 - -ann_left.xbm -file - - - - -2013-08-23T00:54:47.000000Z -bed7766441991ca46073affa4027afaa -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -245 - -tiny_math_greaterequal.xbm -file - - - - -2013-08-23T00:54:47.000000Z -00bb2380cab2e1263aae461aee640cd8 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -264 - -tiny_math_partialdiff.xbm -file - - - - -2013-08-23T00:54:47.000000Z -fec532a68b1e04cf43ecb2d941719b6b -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -259 - -tiny_math_infinity.xbm -file - - - - -2013-08-23T00:54:47.000000Z -748f10ba192dea564bd8f0dd7f94c9a4 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -256 - -CVS -dir - -tiny_parenright.xbm -file - - - - -2013-08-23T00:54:47.000000Z -775c932938d28cea7494a65276181110 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -235 - -tiny_arrowleft.xbm -file - - - - -2013-08-23T00:54:47.000000Z -102e92dc1ba66a16b5ac9fd2c916c583 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -205 - -tiny_less.xbm -file - - - - -2013-08-23T00:54:47.000000Z -dc000d556138b58661bfb24e68752d95 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -193 - -ann_right.xbm -file - - - - -2013-08-23T00:54:47.000000Z -08ef6dc67604a8b5429d97abbcb59eb1 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -248 - -tiny_math_lessequal.xbm -file - - - - -2013-08-23T00:54:47.000000Z -d423d39e18e87067c3f4cc1ab7063584 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -249 - -tiny_bracketright.xbm -file - - - - -2013-08-23T00:54:47.000000Z -996b4b228fb1f8df4357b6800e63dc53 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -245 - -tiny_two.xbm -file - - - - -2013-08-23T00:54:47.000000Z -4653e8359d0e1ffbd8a1ed4f30c7d183 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -188 - -tiny_one.xbm -file - - - - -2013-08-23T00:54:47.000000Z -32b5178b5420d3268d640a62c8080604 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -188 - -tiny_bracketleft.xbm -file - - - - -2013-08-23T00:54:47.000000Z -a9ab178a25c65a8adab75bbb1376a4c0 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -240 - diff --git a/bitmaps/.svn/text-base/ann_alpha.xbm.svn-base b/bitmaps/.svn/text-base/ann_alpha.xbm.svn-base deleted file mode 100644 index e7cfcea..0000000 --- a/bitmaps/.svn/text-base/ann_alpha.xbm.svn-base +++ /dev/null @@ -1,5 +0,0 @@ -#define ann_alpha_width 15 -#define ann_alpha_height 12 -static unsigned char ann_alpha_bits[] = { - 0xe0, 0x03, 0x18, 0x44, 0x0c, 0x4c, 0x06, 0x2c, 0x07, 0x2c, 0x07, 0x1c, - 0x07, 0x0c, 0x07, 0x0c, 0x07, 0x0e, 0x0e, 0x4d, 0xf8, 0x38, 0x00, 0x00}; diff --git a/bitmaps/.svn/text-base/ann_battery.xbm.svn-base b/bitmaps/.svn/text-base/ann_battery.xbm.svn-base deleted file mode 100644 index b4c6a45..0000000 --- a/bitmaps/.svn/text-base/ann_battery.xbm.svn-base +++ /dev/null @@ -1,5 +0,0 @@ -#define ann_battery_width 15 -#define ann_battery_height 12 -static unsigned char ann_battery_bits[] = { - 0x04, 0x10, 0x02, 0x20, 0x12, 0x24, 0x09, 0x48, 0xc9, 0x49, 0xc9, 0x49, - 0xc9, 0x49, 0x09, 0x48, 0x12, 0x24, 0x02, 0x20, 0x04, 0x10, 0x00, 0x00}; diff --git a/bitmaps/.svn/text-base/ann_busy.xbm.svn-base b/bitmaps/.svn/text-base/ann_busy.xbm.svn-base deleted file mode 100644 index 1856111..0000000 --- a/bitmaps/.svn/text-base/ann_busy.xbm.svn-base +++ /dev/null @@ -1,5 +0,0 @@ -#define ann_busy_width 15 -#define ann_busy_height 12 -static unsigned char ann_busy_bits[] = { - 0xfc, 0x1f, 0x08, 0x08, 0x08, 0x08, 0xf0, 0x07, 0xe0, 0x03, 0xc0, 0x01, - 0x40, 0x01, 0x20, 0x02, 0x10, 0x04, 0xc8, 0x09, 0xe8, 0x0b, 0xfc, 0x1f}; diff --git a/bitmaps/.svn/text-base/ann_io.xbm.svn-base b/bitmaps/.svn/text-base/ann_io.xbm.svn-base deleted file mode 100644 index 0c4536d..0000000 --- a/bitmaps/.svn/text-base/ann_io.xbm.svn-base +++ /dev/null @@ -1,5 +0,0 @@ -#define ann_io_width 15 -#define ann_io_height 12 -static unsigned char ann_io_bits[] = { - 0x0c, 0x00, 0x1e, 0x00, 0x33, 0x0c, 0x61, 0x18, 0xcc, 0x30, 0xfe, 0x7f, - 0xfe, 0x7f, 0xcc, 0x30, 0x61, 0x18, 0x33, 0x0c, 0x1e, 0x00, 0x0c, 0x00}; diff --git a/bitmaps/.svn/text-base/ann_left.xbm.svn-base b/bitmaps/.svn/text-base/ann_left.xbm.svn-base deleted file mode 100644 index 604b9d5..0000000 --- a/bitmaps/.svn/text-base/ann_left.xbm.svn-base +++ /dev/null @@ -1,5 +0,0 @@ -#define ann_left_width 15 -#define ann_left_height 12 -static unsigned char ann_left_bits[] = { - 0xfe, 0x3f, 0xff, 0x7f, 0x9f, 0x7f, 0xcf, 0x7f, 0xe7, 0x7f, 0x03, 0x78, - 0x03, 0x70, 0xe7, 0x73, 0xcf, 0x73, 0x9f, 0x73, 0xff, 0x73, 0xfe, 0x33}; diff --git a/bitmaps/.svn/text-base/ann_right.xbm.svn-base b/bitmaps/.svn/text-base/ann_right.xbm.svn-base deleted file mode 100644 index bd9bd6f..0000000 --- a/bitmaps/.svn/text-base/ann_right.xbm.svn-base +++ /dev/null @@ -1,5 +0,0 @@ -#define ann_right_width 15 -#define ann_right_height 12 -static unsigned char ann_right_bits[] = { - 0xfe, 0x3f, 0xff, 0x7f, 0xff, 0x7c, 0xff, 0x79, 0xff, 0x73, 0x0f, 0x60, - 0x07, 0x60, 0xe7, 0x73, 0xe7, 0x79, 0xe7, 0x7c, 0xe7, 0x7f, 0xe6, 0x3f}; diff --git a/bitmaps/.svn/text-base/button_large.xbm.svn-base b/bitmaps/.svn/text-base/button_large.xbm.svn-base deleted file mode 100644 index 11570f8..0000000 --- a/bitmaps/.svn/text-base/button_large.xbm.svn-base +++ /dev/null @@ -1,19 +0,0 @@ -#define button_large_width 46 -#define button_large_height 32 -static unsigned char button_large_bits[] = { - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xf8, 0xff, 0xff, 0xff, 0xff, 0x07, - 0xfc, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, - 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, - 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, - 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, - 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, - 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, - 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, - 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, - 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, - 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, - 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, - 0xfc, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xe0, 0xff, 0xff, 0xff, 0xff, 0x01, - 0x00, 0xfe, 0xff, 0xff, 0x1f, 0x00, 0x00, 0x80, 0xff, 0x7f, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}; diff --git a/bitmaps/.svn/text-base/button_normal.xbm.svn-base b/bitmaps/.svn/text-base/button_normal.xbm.svn-base deleted file mode 100644 index e979828..0000000 --- a/bitmaps/.svn/text-base/button_normal.xbm.svn-base +++ /dev/null @@ -1,17 +0,0 @@ -#define button_normal_width 46 -#define button_normal_height 28 -static unsigned char button_normal_bits[] = { - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xf8, 0xff, 0xff, 0xff, 0xff, 0x07, - 0xfc, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, - 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, - 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, - 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, - 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, - 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, - 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, - 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, - 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, 0xfe, 0xff, 0xff, 0xff, 0xff, 0x1f, - 0xfc, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xe0, 0xff, 0xff, 0xff, 0xff, 0x01, - 0x00, 0xfe, 0xff, 0xff, 0x1f, 0x00, 0x00, 0x80, 0xff, 0x7f, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}; diff --git a/bitmaps/.svn/text-base/button_round.pix.svn-base b/bitmaps/.svn/text-base/button_round.pix.svn-base deleted file mode 100644 index e25abb9..0000000 --- a/bitmaps/.svn/text-base/button_round.pix.svn-base +++ /dev/null @@ -1,157 +0,0 @@ -/* GdkPixbuf RGBA C-Source image dump */ - -#ifdef __SUNPRO_C -#pragma align 4 (button_round) -#endif -#ifdef __GNUC__ -static const guint8 button_round[] __attribute__ ((__aligned__ (4))) = -#else -static const guint8 button_round[] = -#endif -{ "" - /* Pixbuf magic (0x47646b50) */ - "GdkP" - /* length: header (24) + pixel_data (4356) */ - "\0\0\21\34" - /* pixdata_type (0x1010002) */ - "\1\1\0\2" - /* rowstride (132) */ - "\0\0\0\204" - /* width (33) */ - "\0\0\0!" - /* height (33) */ - "\0\0\0!" - /* pixel_data: */ - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\255\0\0\0\244\0\0\0\232\0\0\0\232" - "\0\0\0\232\0\0\0\244\0\0\0\255\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\247\0\0\0\215\0\0\0|\0\0\0o\0\0\0_\0\0\0Z\0\0\0Z\0\0" - "\0_\0\0\0f\0\0\0o\0\0\0\201\0\0\0\225\0\0\0\255\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\247\0\0" - "\0\211\0\0\0h\0\0\0W\0\0\0D\0\0\0:\0\0\0""1\0\0\0/\0\0\0,\0\0\0/\0\0" - "\0""4\0\0\0:\0\0\0H\0\0\0Z\0\0\0r\0\0\0\215\0\0\0\255\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\225\0\0\0o\0\0\0R\0\0\0:\0" - "\0\0*\0\0\0!\0\0\0\34\0\0\0\27\0\0\0\26\0\0\0\26\0\0\0\26\0\0\0\27\0" - "\0\0\35\0\0\0#\0\0\0/\0\0\0A\0\0\0W\0\0\0|\0\0\0\244\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\261\0\0\0\215\0\0\0_\0\0\0D\0\0\0,\0\0\0\35\0\0\0" - "\26\0\0\0\21\0\0\0\16\0\0\0\15\0\0\0\13\0\0\0\13\0\0\0\13\0\0\0\15\0" - "\0\0\16\0\0\0\22\0\0\0\27\0\0\0\37\0\0\0""1\0\0\0K\0\0\0h\0\0\0\225\0" - "\0\0\273\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\211\0\0\0_\0\0\0:\0\0\0#\0\0\0\27\0\0\0\20" - "\0\0\0\14\0\0\0\10\0\0\0\7\0\0\0\6\0\0\0\6\0\0\0\5\0\0\0\6\0\0\0\6\0" - "\0\0\7\0\0\0\11\0\0\0\15\0\0\0\22\0\0\0\31\0\0\0(\0\0\0D\0\0\0h\0\0\0" - "\225\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\222\0\0\0_\0\0\0:\0\0\0!\0\0\0\24\0\0\0\15\0\0\0\11\0" - "\0\0\6\0\0\0\5\0\0\0\4\0\0\0\4\0\0\0\3\0\0\0\3\0\0\0\3\0\0\0\4\0\0\0" - "\4\0\0\0\5\0\0\0\6\0\0\0\11\0\0\0\17\0\0\0\27\0\0\0&\0\0\0D\0\0\0o\0" - "\0\0\244\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\244\0\0\0o\0\0\0A\0\0\0#\0\0\0\24\0\0\0\15\0\0\0\10\0\0\0\5\0\0\0" - "\4\0\0\0\3\0\0\0\3\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0\3\0" - "\0\0\3\0\0\0\4\0\0\0\6\0\0\0\10\0\0\0\16\0\0\0\27\0\0\0*\0\0\0K\0\0\0" - "|\0\0\0\255\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\211" - "\0\0\0O\0\0\0*\0\0\0\27\0\0\0\15\0\0\0\10\0\0\0\5\0\0\0\4\0\0\0\3\0\0" - "\0\2\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0\2" - "\0\0\0\3\0\0\0\4\0\0\0\5\0\0\0\10\0\0\0\17\0\0\0\32\0\0\0""1\0\0\0_\0" - "\0\0\222\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\244\0\0\0f\0\0" - "\0:\0\0\0\35\0\0\0\20\0\0\0\10\0\0\0\5\0\0\0\3\0\0\0\3\0\0\0\2\0\0\0" - "\2\0\0\0\2\0\0\0\2\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\2\0\0\0\2\0\0\0\2\0" - "\0\0\2\0\0\0\3\0\0\0\4\0\0\0\6\0\0\0\12\0\0\0\22\0\0\0!\0\0\0A\0\0\0" - "r\0\0\0\255\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\211\0\0\0R\0\0\0(\0" - "\0\0\24\0\0\0\13\0\0\0\6\0\0\0\4\0\0\0\3\0\0\0\2\0\0\0\2\0\0\0\2\0\0" - "\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\2\0\0\0\2" - "\0\0\0\2\0\0\0\3\0\0\0\4\0\0\0\7\0\0\0\15\0\0\0\31\0\0\0""1\0\0\0_\0" - "\0\0\225\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0y\0\0\0A\0\0\0\37\0\0\0" - "\20\0\0\0\10\0\0\0\5\0\0\0\3\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0\1\0\0\0\1" - "\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\2\0\0" - "\0\2\0\0\0\2\0\0\0\3\0\0\0\5\0\0\0\12\0\0\0\23\0\0\0&\0\0\0O\0\0\0\211" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\247\0\0\0f\0\0\0""4\0\0\0\31\0\0\0\15" - "\0\0\0\6\0\0\0\4\0\0\0\3\0\0\0\2\0\0\0\2\0\0\0\1\0\0\0\1\0\0\0\1\0\0" - "\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\2" - "\0\0\0\2\0\0\0\3\0\0\0\4\0\0\0\10\0\0\0\17\0\0\0\37\0\0\0A\0\0\0y\0\0" - "\0\261\0\0\0\0\0\0\0\0\0\0\0\232\0\0\0_\0\0\0/\0\0\0\27\0\0\0\14\0\0" - "\0\6\0\0\0\3\0\0\0\2\0\0\0\2\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1" - "\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\2\0\0" - "\0\2\0\0\0\3\0\0\0\4\0\0\0\6\0\0\0\15\0\0\0\32\0\0\0""7\0\0\0h\0\0\0" - "\255\0\0\0\0\0\0\0\0\0\0\0\225\0\0\0W\0\0\0*\0\0\0\24\0\0\0\12\0\0\0" - "\5\0\0\0\3\0\0\0\2\0\0\0\2\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0" - "\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0" - "\2\0\0\0\2\0\0\0\4\0\0\0\6\0\0\0\15\0\0\0\27\0\0\0""1\0\0\0f\0\0\0\244" - "\0\0\0\0\0\0\0\0\0\0\0\222\0\0\0R\0\0\0(\0\0\0\23\0\0\0\11\0\0\0\5\0" - "\0\0\3\0\0\0\2\0\0\0\2\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0" - "\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\2\0" - "\0\0\2\0\0\0\4\0\0\0\6\0\0\0\14\0\0\0\27\0\0\0""1\0\0\0_\0\0\0\244\0" - "\0\0\0\0\0\0\0\0\0\0\225\0\0\0W\0\0\0*\0\0\0\24\0\0\0\12\0\0\0\5\0\0" - "\0\3\0\0\0\2\0\0\0\2\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1" - "\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\2\0\0" - "\0\2\0\0\0\4\0\0\0\6\0\0\0\15\0\0\0\27\0\0\0""1\0\0\0f\0\0\0\244\0\0" - "\0\0\0\0\0\0\0\0\0\232\0\0\0_\0\0\0/\0\0\0\26\0\0\0\13\0\0\0\6\0\0\0" - "\3\0\0\0\2\0\0\0\2\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0" - "\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\2\0\0\0\2\0\0\0" - "\3\0\0\0\4\0\0\0\6\0\0\0\15\0\0\0\32\0\0\0""7\0\0\0h\0\0\0\255\0\0\0" - "\0\0\0\0\0\0\0\0\244\0\0\0f\0\0\0""4\0\0\0\31\0\0\0\15\0\0\0\6\0\0\0" - "\4\0\0\0\3\0\0\0\2\0\0\0\2\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0" - "\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\2\0\0\0\2\0\0\0" - "\3\0\0\0\4\0\0\0\10\0\0\0\17\0\0\0\37\0\0\0A\0\0\0r\0\0\0\261\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0y\0\0\0A\0\0\0\37\0\0\0\20\0\0\0\10\0\0\0\5\0\0" - "\0\3\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1" - "\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0\3\0\0" - "\0\5\0\0\0\12\0\0\0\23\0\0\0&\0\0\0O\0\0\0\211\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\211\0\0\0R\0\0\0(\0\0\0\24\0\0\0\13\0\0\0\6\0\0\0\4" - "\0\0\0\3\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0\1\0\0\0\1\0\0\0\1\0\0\0\1\0\0" - "\0\1\0\0\0\1\0\0\0\1\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0\3\0\0\0\4\0\0\0\7" - "\0\0\0\15\0\0\0\27\0\0\0""1\0\0\0_\0\0\0\225\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\244\0\0\0f\0\0\0""7\0\0\0\35\0\0\0\20\0\0\0\10\0\0\0\5" - "\0\0\0\3\0\0\0\3\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0\1\0\0\0\1\0\0" - "\0\1\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0\3\0\0\0\4\0\0\0\6\0\0\0\12" - "\0\0\0\23\0\0\0!\0\0\0D\0\0\0r\0\0\0\255\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\211\0\0\0O\0\0\0*\0\0\0\27\0\0\0\15\0\0\0\10\0\0\0" - "\5\0\0\0\4\0\0\0\3\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0\2\0" - "\0\0\2\0\0\0\2\0\0\0\2\0\0\0\3\0\0\0\4\0\0\0\5\0\0\0\10\0\0\0\17\0\0" - "\0\32\0\0\0""1\0\0\0_\0\0\0\222\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\244\0\0\0o\0\0\0D\0\0\0#\0\0\0\24\0\0\0\15\0\0\0\7\0" - "\0\0\5\0\0\0\4\0\0\0\3\0\0\0\3\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0\2\0\0\0" - "\2\0\0\0\3\0\0\0\3\0\0\0\4\0\0\0\6\0\0\0\10\0\0\0\16\0\0\0\27\0\0\0*" - "\0\0\0K\0\0\0|\0\0\0\255\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\222\0\0\0_\0\0\0:\0\0\0!\0\0\0\24\0\0\0\15\0\0\0\11" - "\0\0\0\6\0\0\0\5\0\0\0\4\0\0\0\4\0\0\0\3\0\0\0\3\0\0\0\3\0\0\0\4\0\0" - "\0\4\0\0\0\5\0\0\0\6\0\0\0\12\0\0\0\17\0\0\0\27\0\0\0&\0\0\0D\0\0\0h" - "\0\0\0\244\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\215\0\0\0_\0\0\0>\0\0\0#\0\0\0\27\0\0\0\20\0\0\0" - "\14\0\0\0\11\0\0\0\7\0\0\0\6\0\0\0\6\0\0\0\5\0\0\0\6\0\0\0\6\0\0\0\7" - "\0\0\0\11\0\0\0\15\0\0\0\22\0\0\0\32\0\0\0*\0\0\0D\0\0\0h\0\0\0\225\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\261\0\0\0\215\0\0\0_\0\0\0D\0\0\0*\0\0\0\35\0\0\0\26" - "\0\0\0\21\0\0\0\15\0\0\0\14\0\0\0\13\0\0\0\12\0\0\0\13\0\0\0\15\0\0\0" - "\17\0\0\0\22\0\0\0\27\0\0\0\37\0\0\0""1\0\0\0K\0\0\0o\0\0\0\225\0\0\0" - "\273\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\225\0\0\0r\0\0\0R\0\0\0:\0\0\0" - "*\0\0\0\37\0\0\0\32\0\0\0\27\0\0\0\26\0\0\0\26\0\0\0\27\0\0\0\31\0\0" - "\0\35\0\0\0#\0\0\0/\0\0\0A\0\0\0Z\0\0\0y\0\0\0\244\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\247\0\0\0\211\0\0\0h\0\0\0R" - "\0\0\0D\0\0\0:\0\0\0""1\0\0\0/\0\0\0,\0\0\0/\0\0\0""4\0\0\0:\0\0\0H\0" - "\0\0Z\0\0\0r\0\0\0\215\0\0\0\255\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\247\0\0\0\215\0\0\0|\0" - "\0\0o\0\0\0f\0\0\0_\0\0\0_\0\0\0_\0\0\0f\0\0\0o\0\0\0\201\0\0\0\225\0" - "\0\0\255\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\255\0" - "\0\0\244\0\0\0\232\0\0\0\232\0\0\0\232\0\0\0\244\0\0\0\255\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" - "\0\0\0\0\0\0\0\0\0"}; - - diff --git a/bitmaps/.svn/text-base/button_round.xbm.svn-base b/bitmaps/.svn/text-base/button_round.xbm.svn-base deleted file mode 100644 index f0d3292..0000000 --- a/bitmaps/.svn/text-base/button_round.xbm.svn-base +++ /dev/null @@ -1,17 +0,0 @@ -#define button_round_width 33 -#define button_round_height 33 -static unsigned char button_round_bits[] = { - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xe0, 0x0f, 0x00, 0x00, 0x00, 0xfc, - 0x7f, 0x00, 0x00, 0x00, 0xff, 0xff, 0x01, 0x00, 0x80, 0xff, 0xff, 0x03, - 0x00, 0xe0, 0xff, 0xff, 0x0f, 0x00, 0xe0, 0xff, 0xff, 0x0f, 0x00, 0xf0, - 0xff, 0xff, 0x1f, 0x00, 0xf8, 0xff, 0xff, 0x3f, 0x00, 0xf8, 0xff, 0xff, - 0x3f, 0x00, 0xfc, 0xff, 0xff, 0x7f, 0x00, 0xfc, 0xff, 0xff, 0x7f, 0x00, - 0xfc, 0xff, 0xff, 0x7f, 0x00, 0xfe, 0xff, 0xff, 0xff, 0x00, 0xfe, 0xff, - 0xff, 0xff, 0x00, 0xfe, 0xff, 0xff, 0xff, 0x00, 0xfe, 0xff, 0xff, 0xff, - 0x00, 0xfe, 0xff, 0xff, 0xff, 0x00, 0xfe, 0xff, 0xff, 0xff, 0x00, 0xfe, - 0xff, 0xff, 0xff, 0x00, 0xfc, 0xff, 0xff, 0x7f, 0x00, 0xfc, 0xff, 0xff, - 0x7f, 0x00, 0xfc, 0xff, 0xff, 0x7f, 0x00, 0xf8, 0xff, 0xff, 0x3f, 0x00, - 0xf8, 0xff, 0xff, 0x3f, 0x00, 0xf0, 0xff, 0xff, 0x1f, 0x00, 0xe0, 0xff, - 0xff, 0x0f, 0x00, 0xe0, 0xff, 0xff, 0x0f, 0x00, 0x80, 0xff, 0xff, 0x03, - 0x00, 0x00, 0xff, 0xff, 0x01, 0x00, 0x00, 0xfc, 0x7f, 0x00, 0x00, 0x00, - 0xe0, 0x0f, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}; diff --git a/bitmaps/.svn/text-base/button_small.xbm.svn-base b/bitmaps/.svn/text-base/button_small.xbm.svn-base deleted file mode 100644 index e3508d3..0000000 --- a/bitmaps/.svn/text-base/button_small.xbm.svn-base +++ /dev/null @@ -1,15 +0,0 @@ -#define button_small_width 36 -#define button_small_height 28 -static unsigned char button_small_bits[] = { - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0xf8, 0xff, 0xff, 0xff, 0x01, 0xfc, 0xff, 0xff, 0xff, - 0x03, 0xfe, 0xff, 0xff, 0xff, 0x07, 0xfe, 0xff, 0xff, 0xff, 0x07, 0xfe, - 0xff, 0xff, 0xff, 0x07, 0xfe, 0xff, 0xff, 0xff, 0x07, 0xfe, 0xff, 0xff, - 0xff, 0x07, 0xfe, 0xff, 0xff, 0xff, 0x07, 0xfe, 0xff, 0xff, 0xff, 0x07, - 0xfe, 0xff, 0xff, 0xff, 0x07, 0xfe, 0xff, 0xff, 0xff, 0x07, 0xfe, 0xff, - 0xff, 0xff, 0x07, 0xfe, 0xff, 0xff, 0xff, 0x07, 0xfe, 0xff, 0xff, 0xff, - 0x07, 0xfe, 0xff, 0xff, 0xff, 0x07, 0xfe, 0xff, 0xff, 0xff, 0x07, 0xfe, - 0xff, 0xff, 0xff, 0x07, 0xfe, 0xff, 0xff, 0xff, 0x07, 0xfe, 0xff, 0xff, - 0xff, 0x07, 0xfc, 0xff, 0xff, 0xff, 0x03, 0xf0, 0xff, 0xff, 0xff, 0x00, - 0x00, 0xff, 0xff, 0x0f, 0x00, 0x00, 0xe0, 0x7f, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}; diff --git a/bitmaps/.svn/text-base/button_tiny.xbm.svn-base b/bitmaps/.svn/text-base/button_tiny.xbm.svn-base deleted file mode 100644 index 39d0abb..0000000 --- a/bitmaps/.svn/text-base/button_tiny.xbm.svn-base +++ /dev/null @@ -1,13 +0,0 @@ -#define button_tiny_width 36 -#define button_tiny_height 22 -static unsigned char button_tiny_bits[] = { - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xf8, 0xff, - 0xff, 0xff, 0x01, 0xfc, 0xff, 0xff, 0xff, 0x03, 0xfe, 0xff, 0xff, 0xff, - 0x07, 0xfe, 0xff, 0xff, 0xff, 0x07, 0xfe, 0xff, 0xff, 0xff, 0x07, 0xfe, - 0xff, 0xff, 0xff, 0x07, 0xfe, 0xff, 0xff, 0xff, 0x07, 0xfe, 0xff, 0xff, - 0xff, 0x07, 0xfe, 0xff, 0xff, 0xff, 0x07, 0xfe, 0xff, 0xff, 0xff, 0x07, - 0xfe, 0xff, 0xff, 0xff, 0x07, 0xfe, 0xff, 0xff, 0xff, 0x07, 0xfe, 0xff, - 0xff, 0xff, 0x07, 0xfe, 0xff, 0xff, 0xff, 0x07, 0xfe, 0xff, 0xff, 0xff, - 0x07, 0xfe, 0xff, 0xff, 0xff, 0x07, 0xfe, 0xff, 0xff, 0xff, 0x07, 0xfc, - 0xff, 0xff, 0xff, 0x03, 0xf8, 0xff, 0xff, 0xff, 0x01, 0x00, 0x00, 0x00, - 0x00, 0x00}; diff --git a/bitmaps/.svn/text-base/tiny_A.xbm.svn-base b/bitmaps/.svn/text-base/tiny_A.xbm.svn-base deleted file mode 100644 index cd0e0d2..0000000 --- a/bitmaps/.svn/text-base/tiny_A.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_A_width 5 -#define tiny_A_height 7 -#define tiny_A_x_hot 0 -#define tiny_A_y_hot 6 -static unsigned char tiny_A_bits[] = { - 0x06, 0x09, 0x09, 0x0f, 0x09, 0x09, 0x09}; diff --git a/bitmaps/.svn/text-base/tiny_B.xbm.svn-base b/bitmaps/.svn/text-base/tiny_B.xbm.svn-base deleted file mode 100644 index 3fa73c1..0000000 --- a/bitmaps/.svn/text-base/tiny_B.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_B_width 5 -#define tiny_B_height 7 -#define tiny_B_x_hot 0 -#define tiny_B_y_hot 6 -static unsigned char tiny_B_bits[] = { - 0x07, 0x09, 0x09, 0x07, 0x09, 0x09, 0x07}; diff --git a/bitmaps/.svn/text-base/tiny_C.xbm.svn-base b/bitmaps/.svn/text-base/tiny_C.xbm.svn-base deleted file mode 100644 index bd10b3e..0000000 --- a/bitmaps/.svn/text-base/tiny_C.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_C_width 5 -#define tiny_C_height 7 -#define tiny_C_x_hot 0 -#define tiny_C_y_hot 6 -static unsigned char tiny_C_bits[] = { - 0x06, 0x09, 0x01, 0x01, 0x01, 0x09, 0x06}; diff --git a/bitmaps/.svn/text-base/tiny_D.xbm.svn-base b/bitmaps/.svn/text-base/tiny_D.xbm.svn-base deleted file mode 100644 index 4c49bf8..0000000 --- a/bitmaps/.svn/text-base/tiny_D.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_D_width 5 -#define tiny_D_height 7 -#define tiny_D_x_hot 0 -#define tiny_D_y_hot 6 -static unsigned char tiny_D_bits[] = { - 0x07, 0x09, 0x09, 0x09, 0x09, 0x09, 0x07}; diff --git a/bitmaps/.svn/text-base/tiny_E.xbm.svn-base b/bitmaps/.svn/text-base/tiny_E.xbm.svn-base deleted file mode 100644 index ee69976..0000000 --- a/bitmaps/.svn/text-base/tiny_E.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_E_width 4 -#define tiny_E_height 7 -#define tiny_E_x_hot 0 -#define tiny_E_y_hot 6 -static unsigned char tiny_E_bits[] = { - 0x17, 0x01, 0x01, 0x03, 0x01, 0x01, 0x17}; diff --git a/bitmaps/.svn/text-base/tiny_F.xbm.svn-base b/bitmaps/.svn/text-base/tiny_F.xbm.svn-base deleted file mode 100644 index 1a998e7..0000000 --- a/bitmaps/.svn/text-base/tiny_F.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_F_width 4 -#define tiny_F_height 7 -#define tiny_F_x_hot 0 -#define tiny_F_y_hot 6 -static unsigned char tiny_F_bits[] = { - 0x07, 0x01, 0x01, 0x03, 0x01, 0x01, 0x01}; diff --git a/bitmaps/.svn/text-base/tiny_G.xbm.svn-base b/bitmaps/.svn/text-base/tiny_G.xbm.svn-base deleted file mode 100644 index e0e0814..0000000 --- a/bitmaps/.svn/text-base/tiny_G.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_G_width 6 -#define tiny_G_height 7 -#define tiny_G_x_hot 0 -#define tiny_G_y_hot 6 -static unsigned char tiny_G_bits[] = { - 0x0e, 0x11, 0x01, 0x01, 0x19, 0x11, 0x0e}; diff --git a/bitmaps/.svn/text-base/tiny_H.xbm.svn-base b/bitmaps/.svn/text-base/tiny_H.xbm.svn-base deleted file mode 100644 index 2efb290..0000000 --- a/bitmaps/.svn/text-base/tiny_H.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_H_width 5 -#define tiny_H_height 7 -#define tiny_H_x_hot 0 -#define tiny_H_y_hot 6 -static unsigned char tiny_H_bits[] = { - 0x09, 0x09, 0x09, 0x0f, 0x09, 0x09, 0x09}; diff --git a/bitmaps/.svn/text-base/tiny_I.xbm.svn-base b/bitmaps/.svn/text-base/tiny_I.xbm.svn-base deleted file mode 100644 index 7c85dee..0000000 --- a/bitmaps/.svn/text-base/tiny_I.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_I_width 4 -#define tiny_I_height 7 -#define tiny_I_x_hot 0 -#define tiny_I_y_hot 6 -static unsigned char tiny_I_bits[] = { - 0x02, 0x02, 0x02, 0x02, 0x02, 0x02, 0x02}; diff --git a/bitmaps/.svn/text-base/tiny_J.xbm.svn-base b/bitmaps/.svn/text-base/tiny_J.xbm.svn-base deleted file mode 100644 index ab7de19..0000000 --- a/bitmaps/.svn/text-base/tiny_J.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_J_width 5 -#define tiny_J_height 7 -#define tiny_J_x_hot 0 -#define tiny_J_y_hot 6 -static unsigned char tiny_J_bits[] = { - 0x08, 0x08, 0x08, 0x08, 0x08, 0x09, 0x06}; diff --git a/bitmaps/.svn/text-base/tiny_K.xbm.svn-base b/bitmaps/.svn/text-base/tiny_K.xbm.svn-base deleted file mode 100644 index f9563c4..0000000 --- a/bitmaps/.svn/text-base/tiny_K.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_K_width 5 -#define tiny_K_height 7 -#define tiny_K_x_hot 0 -#define tiny_K_y_hot 6 -static unsigned char tiny_K_bits[] = { - 0x09, 0x05, 0x05, 0x03, 0x05, 0x05, 0x09}; diff --git a/bitmaps/.svn/text-base/tiny_L.xbm.svn-base b/bitmaps/.svn/text-base/tiny_L.xbm.svn-base deleted file mode 100644 index 946b6f2..0000000 --- a/bitmaps/.svn/text-base/tiny_L.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_L_width 4 -#define tiny_L_height 7 -#define tiny_L_x_hot 0 -#define tiny_L_y_hot 6 -static unsigned char tiny_L_bits[] = { - 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x07}; diff --git a/bitmaps/.svn/text-base/tiny_M.xbm.svn-base b/bitmaps/.svn/text-base/tiny_M.xbm.svn-base deleted file mode 100644 index 4091719..0000000 --- a/bitmaps/.svn/text-base/tiny_M.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_M_width 6 -#define tiny_M_height 7 -#define tiny_M_x_hot 0 -#define tiny_M_y_hot 6 -static unsigned char tiny_M_bits[] = { - 0x11, 0x1b, 0x15, 0x15, 0x11, 0x11, 0x11}; diff --git a/bitmaps/.svn/text-base/tiny_N.xbm.svn-base b/bitmaps/.svn/text-base/tiny_N.xbm.svn-base deleted file mode 100644 index 068d682..0000000 --- a/bitmaps/.svn/text-base/tiny_N.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_N_width 5 -#define tiny_N_height 7 -#define tiny_N_x_hot 0 -#define tiny_N_y_hot 6 -static unsigned char tiny_N_bits[] = { - 0x09, 0x0b, 0x0b, 0x0d, 0x0d, 0x09, 0x09}; diff --git a/bitmaps/.svn/text-base/tiny_O.xbm.svn-base b/bitmaps/.svn/text-base/tiny_O.xbm.svn-base deleted file mode 100644 index 4ef2d53..0000000 --- a/bitmaps/.svn/text-base/tiny_O.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_O_width 5 -#define tiny_O_height 7 -#define tiny_O_x_hot 0 -#define tiny_O_y_hot 6 -static unsigned char tiny_O_bits[] = { - 0x06, 0x09, 0x09, 0x09, 0x09, 0x09, 0x06}; diff --git a/bitmaps/.svn/text-base/tiny_P.xbm.svn-base b/bitmaps/.svn/text-base/tiny_P.xbm.svn-base deleted file mode 100644 index 7fd19eb..0000000 --- a/bitmaps/.svn/text-base/tiny_P.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_P_width 5 -#define tiny_P_height 7 -#define tiny_P_x_hot 0 -#define tiny_P_y_hot 6 -static unsigned char tiny_P_bits[] = { - 0x07, 0x09, 0x09, 0x07, 0x01, 0x01, 0x01}; diff --git a/bitmaps/.svn/text-base/tiny_Q.xbm.svn-base b/bitmaps/.svn/text-base/tiny_Q.xbm.svn-base deleted file mode 100644 index 4ecebc5..0000000 --- a/bitmaps/.svn/text-base/tiny_Q.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_Q_width 6 -#define tiny_Q_height 7 -#define tiny_Q_x_hot 0 -#define tiny_Q_y_hot 6 -static unsigned char tiny_Q_bits[] = { - 0x0e, 0x11, 0x11, 0x11, 0x15, 0x09, 0x16}; diff --git a/bitmaps/.svn/text-base/tiny_R.xbm.svn-base b/bitmaps/.svn/text-base/tiny_R.xbm.svn-base deleted file mode 100644 index 5088b22..0000000 --- a/bitmaps/.svn/text-base/tiny_R.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_R_width 5 -#define tiny_R_height 7 -#define tiny_R_x_hot 0 -#define tiny_R_y_hot 6 -static unsigned char tiny_R_bits[] = { - 0x07, 0x09, 0x09, 0x07, 0x05, 0x09, 0x09}; diff --git a/bitmaps/.svn/text-base/tiny_S.xbm.svn-base b/bitmaps/.svn/text-base/tiny_S.xbm.svn-base deleted file mode 100644 index d567911..0000000 --- a/bitmaps/.svn/text-base/tiny_S.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_S_width 5 -#define tiny_S_height 7 -#define tiny_S_x_hot 0 -#define tiny_S_y_hot 6 -static unsigned char tiny_S_bits[] = { - 0x06, 0x09, 0x01, 0x06, 0x08, 0x09, 0x06}; diff --git a/bitmaps/.svn/text-base/tiny_T.xbm.svn-base b/bitmaps/.svn/text-base/tiny_T.xbm.svn-base deleted file mode 100644 index 4cb3ea4..0000000 --- a/bitmaps/.svn/text-base/tiny_T.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_T_width 5 -#define tiny_T_height 7 -#define tiny_T_x_hot 1 -#define tiny_T_y_hot 6 -static unsigned char tiny_T_bits[] = { - 0x1f, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04}; diff --git a/bitmaps/.svn/text-base/tiny_U.xbm.svn-base b/bitmaps/.svn/text-base/tiny_U.xbm.svn-base deleted file mode 100644 index f9df60e..0000000 --- a/bitmaps/.svn/text-base/tiny_U.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_U_width 5 -#define tiny_U_height 7 -#define tiny_U_x_hot 0 -#define tiny_U_y_hot 6 -static unsigned char tiny_U_bits[] = { - 0x09, 0x09, 0x09, 0x09, 0x09, 0x09, 0x06}; diff --git a/bitmaps/.svn/text-base/tiny_V.xbm.svn-base b/bitmaps/.svn/text-base/tiny_V.xbm.svn-base deleted file mode 100644 index 07bc1cc..0000000 --- a/bitmaps/.svn/text-base/tiny_V.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_V_width 5 -#define tiny_V_height 7 -#define tiny_V_x_hot 0 -#define tiny_V_y_hot 6 -static unsigned char tiny_V_bits[] = { - 0x09, 0x09, 0x09, 0x09, 0x09, 0x06, 0x06}; diff --git a/bitmaps/.svn/text-base/tiny_W.xbm.svn-base b/bitmaps/.svn/text-base/tiny_W.xbm.svn-base deleted file mode 100644 index c8a878e..0000000 --- a/bitmaps/.svn/text-base/tiny_W.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_W_width 6 -#define tiny_W_height 7 -#define tiny_W_x_hot 0 -#define tiny_W_y_hot 6 -static unsigned char tiny_W_bits[] = { - 0x11, 0x11, 0x11, 0x15, 0x15, 0x1b, 0x11}; diff --git a/bitmaps/.svn/text-base/tiny_X.xbm.svn-base b/bitmaps/.svn/text-base/tiny_X.xbm.svn-base deleted file mode 100644 index 82b3429..0000000 --- a/bitmaps/.svn/text-base/tiny_X.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_X_width 5 -#define tiny_X_height 7 -#define tiny_X_x_hot 0 -#define tiny_X_y_hot 6 -static unsigned char tiny_X_bits[] = { - 0x09, 0x09, 0x06, 0x06, 0x06, 0x09, 0x09}; diff --git a/bitmaps/.svn/text-base/tiny_Y.xbm.svn-base b/bitmaps/.svn/text-base/tiny_Y.xbm.svn-base deleted file mode 100644 index 1b51bf6..0000000 --- a/bitmaps/.svn/text-base/tiny_Y.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_Y_width 6 -#define tiny_Y_height 7 -#define tiny_Y_x_hot 0 -#define tiny_Y_y_hot 6 -static unsigned char tiny_Y_bits[] = { - 0x11, 0x11, 0x0a, 0x04, 0x04, 0x04, 0x04}; diff --git a/bitmaps/.svn/text-base/tiny_Z.xbm.svn-base b/bitmaps/.svn/text-base/tiny_Z.xbm.svn-base deleted file mode 100644 index f20296b..0000000 --- a/bitmaps/.svn/text-base/tiny_Z.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_Z_width 5 -#define tiny_Z_height 7 -#define tiny_Z_x_hot 0 -#define tiny_Z_y_hot 6 -static unsigned char tiny_Z_bits[] = { - 0x0f, 0x08, 0x04, 0x04, 0x02, 0x01, 0x0f}; diff --git a/bitmaps/.svn/text-base/tiny__i.xbm.svn-base b/bitmaps/.svn/text-base/tiny__i.xbm.svn-base deleted file mode 100644 index 4706d51..0000000 --- a/bitmaps/.svn/text-base/tiny__i.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_i_width 4 -#define tiny_i_height 7 -#define tiny_i_x_hot 0 -#define tiny_i_y_hot 6 -static unsigned char tiny_i_bits[] = { - 0x02, 0x00, 0x00, 0x02, 0x02, 0x02, 0x02}; diff --git a/bitmaps/.svn/text-base/tiny_ampersand.xbm.svn-base b/bitmaps/.svn/text-base/tiny_ampersand.xbm.svn-base deleted file mode 100644 index 86f807b..0000000 --- a/bitmaps/.svn/text-base/tiny_ampersand.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_ampersand_width 6 -#define tiny_ampersand_height 7 -#define tiny_ampersand_x_hot 0 -#define tiny_ampersand_y_hot 6 -static unsigned char tiny_ampersand_bits[] = { - 0x06, 0x09, 0x06, 0x16, 0x09, 0x09, 0x16}; diff --git a/bitmaps/.svn/text-base/tiny_arrowleft.xbm.svn-base b/bitmaps/.svn/text-base/tiny_arrowleft.xbm.svn-base deleted file mode 100644 index 25a8126..0000000 --- a/bitmaps/.svn/text-base/tiny_arrowleft.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_arrowleft_width 7 -#define tiny_arrowleft_height 5 -#define tiny_arrowleft_x_hot 0 -#define tiny_arrowleft_y_hot 4 -static unsigned char tiny_arrowleft_bits[] = { - 0x02, 0x3f, 0x02, 0x00, 0x00 }; diff --git a/bitmaps/.svn/text-base/tiny_arrowright.xbm.svn-base b/bitmaps/.svn/text-base/tiny_arrowright.xbm.svn-base deleted file mode 100644 index ab37763..0000000 --- a/bitmaps/.svn/text-base/tiny_arrowright.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_arrowright_width 7 -#define tiny_arrowright_height 5 -#define tiny_arrowright_x_hot 0 -#define tiny_arrowright_y_hot 4 -static unsigned char tiny_arrowright_bits[] = { - 0x10, 0x3f, 0x10, 0x00, 0x00 }; diff --git a/bitmaps/.svn/text-base/tiny_braceleft.xbm.svn-base b/bitmaps/.svn/text-base/tiny_braceleft.xbm.svn-base deleted file mode 100644 index 0f6ba86..0000000 --- a/bitmaps/.svn/text-base/tiny_braceleft.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_braceleft_width 4 -#define tiny_braceleft_height 9 -#define tiny_braceleft_x_hot 0 -#define tiny_braceleft_y_hot 7 -static unsigned char tiny_braceleft_bits[] = { - 0x04, 0x02, 0x02, 0x02, 0x01, 0x02, 0x02, 0x02, 0x04}; diff --git a/bitmaps/.svn/text-base/tiny_braceright.xbm.svn-base b/bitmaps/.svn/text-base/tiny_braceright.xbm.svn-base deleted file mode 100644 index 2af45ee..0000000 --- a/bitmaps/.svn/text-base/tiny_braceright.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_braceright_width 4 -#define tiny_braceright_height 9 -#define tiny_braceright_x_hot 0 -#define tiny_braceright_y_hot 7 -static unsigned char tiny_braceright_bits[] = { - 0x01, 0x02, 0x02, 0x02, 0x04, 0x02, 0x02, 0x02, 0x01}; diff --git a/bitmaps/.svn/text-base/tiny_bracketleft.xbm.svn-base b/bitmaps/.svn/text-base/tiny_bracketleft.xbm.svn-base deleted file mode 100644 index f3ae7ea..0000000 --- a/bitmaps/.svn/text-base/tiny_bracketleft.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_bracketleft_width 4 -#define tiny_bracketleft_height 9 -#define tiny_bracketleft_x_hot 0 -#define tiny_bracketleft_y_hot 7 -static unsigned char tiny_bracketleft_bits[] = { - 0x07, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x07}; diff --git a/bitmaps/.svn/text-base/tiny_bracketright.xbm.svn-base b/bitmaps/.svn/text-base/tiny_bracketright.xbm.svn-base deleted file mode 100644 index de4d785..0000000 --- a/bitmaps/.svn/text-base/tiny_bracketright.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_bracketright_width 4 -#define tiny_bracketright_height 9 -#define tiny_bracketright_x_hot 0 -#define tiny_bracketright_y_hot 7 -static unsigned char tiny_bracketright_bits[] = { - 0x07, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x07}; diff --git a/bitmaps/.svn/text-base/tiny_colon.xbm.svn-base b/bitmaps/.svn/text-base/tiny_colon.xbm.svn-base deleted file mode 100644 index 0dc2622..0000000 --- a/bitmaps/.svn/text-base/tiny_colon.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_colon_width 3 -#define tiny_colon_height 6 -#define tiny_colon_x_hot 0 -#define tiny_colon_y_hot 5 -static unsigned char tiny_colon_bits[] = { - 0x03, 0x03, 0x00, 0x00, 0x03, 0x03 }; diff --git a/bitmaps/.svn/text-base/tiny_comma.xbm.svn-base b/bitmaps/.svn/text-base/tiny_comma.xbm.svn-base deleted file mode 100644 index 2adbc03..0000000 --- a/bitmaps/.svn/text-base/tiny_comma.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_comma_width 4 -#define tiny_comma_height 3 -#define tiny_comma_x_hot 0 -#define tiny_comma_y_hot 1 -static unsigned char tiny_comma_bits[] = { - 0x06, 0x06, 0x03}; diff --git a/bitmaps/.svn/text-base/tiny_equal.xbm.svn-base b/bitmaps/.svn/text-base/tiny_equal.xbm.svn-base deleted file mode 100644 index 512b5c8..0000000 --- a/bitmaps/.svn/text-base/tiny_equal.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_equal_width 5 -#define tiny_equal_height 5 -#define tiny_equal_x_hot 0 -#define tiny_equal_y_hot 4 -static unsigned char tiny_equal_bits[] = { - 0x0f, 0x00, 0x0f, 0x00, 0x00}; diff --git a/bitmaps/.svn/text-base/tiny_greater.xbm.svn-base b/bitmaps/.svn/text-base/tiny_greater.xbm.svn-base deleted file mode 100644 index 44d9caf..0000000 --- a/bitmaps/.svn/text-base/tiny_greater.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_greater_width 5 -#define tiny_greater_height 7 -#define tiny_greater_x_hot 0 -#define tiny_greater_y_hot 6 -static unsigned char tiny_greater_bits[] = { - 0x01, 0x02, 0x04, 0x08, 0x04, 0x02, 0x01}; diff --git a/bitmaps/.svn/text-base/tiny_guillemotleft.xbm.svn-base b/bitmaps/.svn/text-base/tiny_guillemotleft.xbm.svn-base deleted file mode 100644 index 96fc88a..0000000 --- a/bitmaps/.svn/text-base/tiny_guillemotleft.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_guillemotleft_width 11 -#define tiny_guillemotleft_height 6 -#define tiny_guillemotleft_x_hot 0 -#define tiny_guillemotleft_y_hot 5 -static unsigned char tiny_guillemotleft_bits[] = { - 0x18, 0x03, 0xc6, 0x00, 0x21, 0x00, 0xc6, 0x00, 0x18, 0x03, 0x00, 0x00}; diff --git a/bitmaps/.svn/text-base/tiny_guillemotright.xbm.svn-base b/bitmaps/.svn/text-base/tiny_guillemotright.xbm.svn-base deleted file mode 100644 index 50d736e..0000000 --- a/bitmaps/.svn/text-base/tiny_guillemotright.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_guillemotright_width 11 -#define tiny_guillemotright_height 6 -#define tiny_guillemotright_x_hot 0 -#define tiny_guillemotright_y_hot 5 -static unsigned char tiny_guillemotright_bits[] = { - 0x63, 0x00, 0x8c, 0x01, 0x10, 0x02, 0x8c, 0x01, 0x63, 0x00, 0x00, 0x00}; diff --git a/bitmaps/.svn/text-base/tiny_hyphen.xbm.svn-base b/bitmaps/.svn/text-base/tiny_hyphen.xbm.svn-base deleted file mode 100644 index 4696e05..0000000 --- a/bitmaps/.svn/text-base/tiny_hyphen.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_hyphen_width 5 -#define tiny_hyphen_height 4 -#define tiny_hyphen_x_hot 0 -#define tiny_hyphen_y_hot 3 -static unsigned char tiny_hyphen_bits[] = { - 0x0f, 0x00, 0x00, 0x00}; diff --git a/bitmaps/.svn/text-base/tiny_large_comma.xbm.svn-base b/bitmaps/.svn/text-base/tiny_large_comma.xbm.svn-base deleted file mode 100644 index f130f02..0000000 --- a/bitmaps/.svn/text-base/tiny_large_comma.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_large_comma_width 4 -#define tiny_large_comma_height 6 -#define tiny_large_comma_x_hot 0 -#define tiny_large_comma_y_hot 2 -static unsigned char tiny_large_comma_bits[] = { - 0x07, 0x07, 0x07, 0x04, 0x02, 0x01 }; diff --git a/bitmaps/.svn/text-base/tiny_less.xbm.svn-base b/bitmaps/.svn/text-base/tiny_less.xbm.svn-base deleted file mode 100644 index c9ee854..0000000 --- a/bitmaps/.svn/text-base/tiny_less.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_less_width 5 -#define tiny_less_height 7 -#define tiny_less_x_hot 0 -#define tiny_less_y_hot 6 -static unsigned char tiny_less_bits[] = { - 0x08, 0x04, 0x02, 0x01, 0x02, 0x04, 0x08}; diff --git a/bitmaps/.svn/text-base/tiny_math_arrowleft.xbm.svn-base b/bitmaps/.svn/text-base/tiny_math_arrowleft.xbm.svn-base deleted file mode 100644 index 117ee37..0000000 --- a/bitmaps/.svn/text-base/tiny_math_arrowleft.xbm.svn-base +++ /dev/null @@ -1,7 +0,0 @@ -#define tiny_math_arrowleft_width 12 -#define tiny_math_arrowleft_height 6 -#define tiny_math_arrowleft_x_hot 0 -#define tiny_math_arrowleft_y_hot 5 -static unsigned char tiny_math_arrowleft_bits[] = { - 0x10, 0x00, 0x1c, 0x00, 0xff, 0x07, 0x1c, 0x00, 0x10, 0x00, 0x00, 0x00 - }; diff --git a/bitmaps/.svn/text-base/tiny_math_arrowright.xbm.svn-base b/bitmaps/.svn/text-base/tiny_math_arrowright.xbm.svn-base deleted file mode 100644 index 5f23875..0000000 --- a/bitmaps/.svn/text-base/tiny_math_arrowright.xbm.svn-base +++ /dev/null @@ -1,7 +0,0 @@ -#define tiny_math_arrowright_width 12 -#define tiny_math_arrowright_height 6 -#define tiny_math_arrowright_x_hot 0 -#define tiny_math_arrowright_y_hot 5 -static unsigned char tiny_math_arrowright_bits[] = { - 0x40, 0x00, 0xc0, 0x01, 0xff, 0x07, 0xc0, 0x01, 0x40, 0x00, 0x00, 0x00 - }; diff --git a/bitmaps/.svn/text-base/tiny_math_downarrowleft.xbm.svn-base b/bitmaps/.svn/text-base/tiny_math_downarrowleft.xbm.svn-base deleted file mode 100644 index 103f777..0000000 --- a/bitmaps/.svn/text-base/tiny_math_downarrowleft.xbm.svn-base +++ /dev/null @@ -1,7 +0,0 @@ -#define tiny_math_downarrowleft_width 12 -#define tiny_math_downarrowleft_height 8 -#define tiny_math_downarrowleft_x_hot 0 -#define tiny_math_downarrowleft_y_hot 7 -static unsigned char tiny_math_downarrowleft_bits[] = { - 0x00, 0x04, 0x00, 0x04, 0x10, 0x04, 0x1c, 0x04, 0xff, 0x07, 0x1c, 0x00, - 0x10, 0x00, 0x00, 0x00 }; diff --git a/bitmaps/.svn/text-base/tiny_math_downarrowright.xbm.svn-base b/bitmaps/.svn/text-base/tiny_math_downarrowright.xbm.svn-base deleted file mode 100644 index bf7c8bc..0000000 --- a/bitmaps/.svn/text-base/tiny_math_downarrowright.xbm.svn-base +++ /dev/null @@ -1,7 +0,0 @@ -#define tiny_math_downarrowright_width 12 -#define tiny_math_downarrowright_height 8 -#define tiny_math_downarrowright_x_hot 0 -#define tiny_math_downarrowright_y_hot 7 -static unsigned char tiny_math_downarrowright_bits[] = { - 0x01, 0x00, 0x01, 0x00, 0x41, 0x00, 0xc1, 0x01, 0xff, 0x07, 0xc0, 0x01, - 0x40, 0x00, 0x00, 0x00 }; diff --git a/bitmaps/.svn/text-base/tiny_math_e.xbm.svn-base b/bitmaps/.svn/text-base/tiny_math_e.xbm.svn-base deleted file mode 100644 index 1cb6fa3..0000000 --- a/bitmaps/.svn/text-base/tiny_math_e.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_math_e_width 6 -#define tiny_math_e_height 6 -#define tiny_math_e_x_hot 0 -#define tiny_math_e_y_hot 5 -static unsigned char tiny_math_e_bits[] = { - 0x0c, 0x12, 0x09, 0x07, 0x11, 0x0e}; diff --git a/bitmaps/.svn/text-base/tiny_math_equal.xbm.svn-base b/bitmaps/.svn/text-base/tiny_math_equal.xbm.svn-base deleted file mode 100644 index cf30759..0000000 --- a/bitmaps/.svn/text-base/tiny_math_equal.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_math_equal_width 7 -#define tiny_math_equal_height 6 -#define tiny_math_equal_x_hot 0 -#define tiny_math_equal_y_hot 5 -static unsigned char tiny_math_equal_bits[] = { - 0x3f, 0x00, 0x00, 0x3f, 0x00, 0x00}; diff --git a/bitmaps/.svn/text-base/tiny_math_greater.xbm.svn-base b/bitmaps/.svn/text-base/tiny_math_greater.xbm.svn-base deleted file mode 100644 index 581b902..0000000 --- a/bitmaps/.svn/text-base/tiny_math_greater.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_math_greater_width 6 -#define tiny_math_greater_height 7 -#define tiny_math_greater_x_hot 0 -#define tiny_math_greater_y_hot 6 -static unsigned char tiny_math_greater_bits[] = { - 0x03, 0x0c, 0x10, 0x0c, 0x03, 0x00, 0x00}; diff --git a/bitmaps/.svn/text-base/tiny_math_greaterequal.xbm.svn-base b/bitmaps/.svn/text-base/tiny_math_greaterequal.xbm.svn-base deleted file mode 100644 index 7675bf9..0000000 --- a/bitmaps/.svn/text-base/tiny_math_greaterequal.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_math_greaterequal_width 6 -#define tiny_math_greaterequal_height 8 -#define tiny_math_greaterequal_x_hot 0 -#define tiny_math_greaterequal_y_hot 7 -static unsigned char tiny_math_greaterequal_bits[] = { - 0x03, 0x0c, 0x10, 0x0c, 0x03, 0x30, 0x0c, 0x03}; diff --git a/bitmaps/.svn/text-base/tiny_math_infinity.xbm.svn-base b/bitmaps/.svn/text-base/tiny_math_infinity.xbm.svn-base deleted file mode 100644 index ed48a6e..0000000 --- a/bitmaps/.svn/text-base/tiny_math_infinity.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_math_infinity_width 13 -#define tiny_math_infinity_height 5 -#define tiny_math_infinity_x_hot 0 -#define tiny_math_infinity_y_hot 4 -static unsigned char tiny_math_infinity_bits[] = { - 0x9e, 0x07, 0x61, 0x08, 0x61, 0x08, 0x9e, 0x07, 0x00, 0x00 }; diff --git a/bitmaps/.svn/text-base/tiny_math_integral.xbm.svn-base b/bitmaps/.svn/text-base/tiny_math_integral.xbm.svn-base deleted file mode 100644 index 1a91ed9..0000000 --- a/bitmaps/.svn/text-base/tiny_math_integral.xbm.svn-base +++ /dev/null @@ -1,7 +0,0 @@ -#define tiny_math_integral_width 9 -#define tiny_math_integral_height 10 -#define tiny_math_integral_x_hot 0 -#define tiny_math_integral_y_hot 8 -static unsigned char tiny_math_integral_bits[] = { - 0x60, 0x00, 0x90, 0x00, 0x10, 0x00, 0x10, 0x00, 0x10, 0x00, 0x08, 0x00, - 0x08, 0x00, 0x08, 0x00, 0x09, 0x00, 0x06, 0x00}; diff --git a/bitmaps/.svn/text-base/tiny_math_less.xbm.svn-base b/bitmaps/.svn/text-base/tiny_math_less.xbm.svn-base deleted file mode 100644 index 9efe921..0000000 --- a/bitmaps/.svn/text-base/tiny_math_less.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_math_less_width 6 -#define tiny_math_less_height 7 -#define tiny_math_less_x_hot 0 -#define tiny_math_less_y_hot 6 -static unsigned char tiny_math_less_bits[] = { - 0x18, 0x06, 0x01, 0x06, 0x18, 0x00, 0x00}; diff --git a/bitmaps/.svn/text-base/tiny_math_lessequal.xbm.svn-base b/bitmaps/.svn/text-base/tiny_math_lessequal.xbm.svn-base deleted file mode 100644 index ea49a90..0000000 --- a/bitmaps/.svn/text-base/tiny_math_lessequal.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_math_lessequal_width 6 -#define tiny_math_lessequal_height 8 -#define tiny_math_lessequal_x_hot 0 -#define tiny_math_lessequal_y_hot 7 -static unsigned char tiny_math_lessequal_bits[] = { - 0x30, 0x0c, 0x02, 0x0c, 0x30, 0x03, 0x0c, 0x30}; diff --git a/bitmaps/.svn/text-base/tiny_math_notequal.xbm.svn-base b/bitmaps/.svn/text-base/tiny_math_notequal.xbm.svn-base deleted file mode 100644 index 9b71a4f..0000000 --- a/bitmaps/.svn/text-base/tiny_math_notequal.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_math_notequal_width 7 -#define tiny_math_notequal_height 8 -#define tiny_math_notequal_x_hot 0 -#define tiny_math_notequal_y_hot 7 -static unsigned char tiny_math_notequal_bits[] = { - 0x08, 0x08, 0x3f, 0x08, 0x04, 0x3f, 0x04, 0x04}; diff --git a/bitmaps/.svn/text-base/tiny_math_numbersign.xbm.svn-base b/bitmaps/.svn/text-base/tiny_math_numbersign.xbm.svn-base deleted file mode 100644 index caf5b69..0000000 --- a/bitmaps/.svn/text-base/tiny_math_numbersign.xbm.svn-base +++ /dev/null @@ -1,7 +0,0 @@ -#define tiny_math_numbersign_width 10 -#define tiny_math_numbersign_height 8 -#define tiny_math_numbersign_x_hot 0 -#define tiny_math_numbersign_y_hot 7 -static unsigned char tiny_math_numbersign_bits[] = { - 0x48, 0x00, 0x48, 0x00, 0xfe, 0x01, 0x48, 0x00, 0x24, 0x00, 0xff, 0x00, - 0x24, 0x00, 0x24, 0x00}; diff --git a/bitmaps/.svn/text-base/tiny_math_partialdiff.xbm.svn-base b/bitmaps/.svn/text-base/tiny_math_partialdiff.xbm.svn-base deleted file mode 100644 index cf83622..0000000 --- a/bitmaps/.svn/text-base/tiny_math_partialdiff.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_math_partialdiff_width 6 -#define tiny_math_partialdiff_height 8 -#define tiny_math_partialdiff_x_hot 0 -#define tiny_math_partialdiff_y_hot 7 -static unsigned char tiny_math_partialdiff_bits[] = { - 0x04, 0x08, 0x08, 0x1e, 0x11, 0x11, 0x11, 0x0e}; diff --git a/bitmaps/.svn/text-base/tiny_math_pi.xbm.svn-base b/bitmaps/.svn/text-base/tiny_math_pi.xbm.svn-base deleted file mode 100644 index 2d3690d..0000000 --- a/bitmaps/.svn/text-base/tiny_math_pi.xbm.svn-base +++ /dev/null @@ -1,7 +0,0 @@ -#define tiny_math_pi_width 9 -#define tiny_math_pi_height 6 -#define tiny_math_pi_x_hot 0 -#define tiny_math_pi_y_hot 5 -static unsigned char tiny_math_pi_bits[] = { - 0xfe, 0x00, 0x25, 0x00, 0x24, 0x00, 0x24, 0x00, 0xa4, 0x00, 0x42, 0x00 - }; diff --git a/bitmaps/.svn/text-base/tiny_math_radical.xbm.svn-base b/bitmaps/.svn/text-base/tiny_math_radical.xbm.svn-base deleted file mode 100644 index c281986..0000000 --- a/bitmaps/.svn/text-base/tiny_math_radical.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_math_radical_width 8 -#define tiny_math_radical_height 11 -#define tiny_math_radical_x_hot 0 -#define tiny_math_radical_y_hot 8 -static unsigned char tiny_math_radical_bits[] = { - 0x40, 0x40, 0x40, 0x20, 0x20, 0x20, 0x17, 0x14, 0x1c, 0x08, 0x08}; diff --git a/bitmaps/.svn/text-base/tiny_math_summation.xbm.svn-base b/bitmaps/.svn/text-base/tiny_math_summation.xbm.svn-base deleted file mode 100644 index d83209f..0000000 --- a/bitmaps/.svn/text-base/tiny_math_summation.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_math_summation_width 6 -#define tiny_math_summation_height 9 -#define tiny_math_summation_x_hot 0 -#define tiny_math_summation_y_hot 7 -static unsigned char tiny_math_summation_bits[] = { - 0x1f, 0x11, 0x02, 0x04, 0x08, 0x04, 0x02, 0x11, 0x1f}; diff --git a/bitmaps/.svn/text-base/tiny_math_x.xbm.svn-base b/bitmaps/.svn/text-base/tiny_math_x.xbm.svn-base deleted file mode 100644 index e77a564..0000000 --- a/bitmaps/.svn/text-base/tiny_math_x.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_math_x_width 8 -#define tiny_math_x_height 6 -#define tiny_math_x_x_hot 0 -#define tiny_math_x_y_hot 5 -static unsigned char tiny_math_x_bits[] = { - 0x26, 0x14, 0x08, 0x14, 0x53, 0x21}; diff --git a/bitmaps/.svn/text-base/tiny_math_y.xbm.svn-base b/bitmaps/.svn/text-base/tiny_math_y.xbm.svn-base deleted file mode 100644 index 71c1a76..0000000 --- a/bitmaps/.svn/text-base/tiny_math_y.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_math_y_width 7 -#define tiny_math_y_height 9 -#define tiny_math_y_x_hot 1 -#define tiny_math_y_y_hot 6 -static unsigned char tiny_math_y_bits[] = { - 0x26, 0x24, 0x24, 0x14, 0x18, 0x08, 0x08, 0x05, 0x03}; diff --git a/bitmaps/.svn/text-base/tiny_notdef.xbm.svn-base b/bitmaps/.svn/text-base/tiny_notdef.xbm.svn-base deleted file mode 100644 index 57f36b7..0000000 --- a/bitmaps/.svn/text-base/tiny_notdef.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_notdef_width 4 -#define tiny_notdef_height 5 -#define tiny_notdef_x_hot 0 -#define tiny_notdef_y_hot 4 -static unsigned char tiny_notdef_bits[] = { - 0x07, 0x07, 0x07, 0x00, 0x00}; diff --git a/bitmaps/.svn/text-base/tiny_numbersign.xbm.svn-base b/bitmaps/.svn/text-base/tiny_numbersign.xbm.svn-base deleted file mode 100644 index 82931c6..0000000 --- a/bitmaps/.svn/text-base/tiny_numbersign.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_numbersign_width 6 -#define tiny_numbersign_height 6 -#define tiny_numbersign_x_hot 0 -#define tiny_numbersign_y_hot 5 -static unsigned char tiny_numbersign_bits[] = { - 0x0a, 0x1f, 0x0a, 0x0a, 0x1f, 0x0a}; diff --git a/bitmaps/.svn/text-base/tiny_one.xbm.svn-base b/bitmaps/.svn/text-base/tiny_one.xbm.svn-base deleted file mode 100644 index 050a714..0000000 --- a/bitmaps/.svn/text-base/tiny_one.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_one_width 3 -#define tiny_one_height 7 -#define tiny_one_x_hot 0 -#define tiny_one_y_hot 6 -static unsigned char tiny_one_bits[] = { - 0x03, 0x02, 0x02, 0x02, 0x02, 0x02, 0x02}; diff --git a/bitmaps/.svn/text-base/tiny_overscore.xbm.svn-base b/bitmaps/.svn/text-base/tiny_overscore.xbm.svn-base deleted file mode 100644 index c3fb694..0000000 --- a/bitmaps/.svn/text-base/tiny_overscore.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_overscore_width 6 -#define tiny_overscore_height 9 -#define tiny_overscore_x_hot 1 -#define tiny_overscore_y_hot 8 -static unsigned char tiny_overscore_bits[] = { - 0x3f, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}; diff --git a/bitmaps/.svn/text-base/tiny_parenleft.xbm.svn-base b/bitmaps/.svn/text-base/tiny_parenleft.xbm.svn-base deleted file mode 100644 index 3631fa9..0000000 --- a/bitmaps/.svn/text-base/tiny_parenleft.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_parenleft_width 4 -#define tiny_parenleft_height 9 -#define tiny_parenleft_x_hot 0 -#define tiny_parenleft_y_hot 7 -static unsigned char tiny_parenleft_bits[] = { - 0x04, 0x02, 0x02, 0x01, 0x01, 0x01, 0x02, 0x02, 0x04}; diff --git a/bitmaps/.svn/text-base/tiny_parenright.xbm.svn-base b/bitmaps/.svn/text-base/tiny_parenright.xbm.svn-base deleted file mode 100644 index 82b182b..0000000 --- a/bitmaps/.svn/text-base/tiny_parenright.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_parenright_width 4 -#define tiny_parenright_height 9 -#define tiny_parenright_x_hot 0 -#define tiny_parenright_y_hot 7 -static unsigned char tiny_parenright_bits[] = { - 0x01, 0x02, 0x02, 0x04, 0x04, 0x04, 0x02, 0x02, 0x01}; diff --git a/bitmaps/.svn/text-base/tiny_period.xbm.svn-base b/bitmaps/.svn/text-base/tiny_period.xbm.svn-base deleted file mode 100644 index 705a7c8..0000000 --- a/bitmaps/.svn/text-base/tiny_period.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_period_width 3 -#define tiny_period_height 2 -#define tiny_period_x_hot 0 -#define tiny_period_y_hot 1 -static unsigned char tiny_period_bits[] = { - 0x03, 0x03}; diff --git a/bitmaps/.svn/text-base/tiny_quotedbl.xbm.svn-base b/bitmaps/.svn/text-base/tiny_quotedbl.xbm.svn-base deleted file mode 100644 index 8ff40d0..0000000 --- a/bitmaps/.svn/text-base/tiny_quotedbl.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_quotedbl_width 4 -#define tiny_quotedbl_height 7 -#define tiny_quotedbl_x_hot 0 -#define tiny_quotedbl_y_hot 6 -static unsigned char tiny_quotedbl_bits[] = { - 0x05, 0x05, 0x05, 0x00, 0x00, 0x00, 0x00}; diff --git a/bitmaps/.svn/text-base/tiny_slash.xbm.svn-base b/bitmaps/.svn/text-base/tiny_slash.xbm.svn-base deleted file mode 100644 index c747f38..0000000 --- a/bitmaps/.svn/text-base/tiny_slash.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_slash_width 4 -#define tiny_slash_height 7 -#define tiny_slash_x_hot 0 -#define tiny_slash_y_hot 6 -static unsigned char tiny_slash_bits[] = { - 0x04, 0x04, 0x02, 0x02, 0x02, 0x01, 0x01}; diff --git a/bitmaps/.svn/text-base/tiny_three.xbm.svn-base b/bitmaps/.svn/text-base/tiny_three.xbm.svn-base deleted file mode 100644 index ba91803..0000000 --- a/bitmaps/.svn/text-base/tiny_three.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_three_width 5 -#define tiny_three_height 7 -#define tiny_three_x_hot 0 -#define tiny_three_y_hot 6 -static unsigned char tiny_three_bits[] = { - 0x06, 0x09, 0x08, 0x06, 0x08, 0x09, 0x06}; diff --git a/bitmaps/.svn/text-base/tiny_two.xbm.svn-base b/bitmaps/.svn/text-base/tiny_two.xbm.svn-base deleted file mode 100644 index af93ea9..0000000 --- a/bitmaps/.svn/text-base/tiny_two.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_two_width 5 -#define tiny_two_height 7 -#define tiny_two_x_hot 0 -#define tiny_two_y_hot 6 -static unsigned char tiny_two_bits[] = { - 0x06, 0x09, 0x08, 0x08, 0x04, 0x02, 0x0f}; diff --git a/bitmaps/.svn/text-base/tiny_twosuperior.xbm.svn-base b/bitmaps/.svn/text-base/tiny_twosuperior.xbm.svn-base deleted file mode 100644 index 8761f31..0000000 --- a/bitmaps/.svn/text-base/tiny_twosuperior.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_twosuperior_width 5 -#define tiny_twosuperior_height 9 -#define tiny_twosuperior_x_hot 0 -#define tiny_twosuperior_y_hot 8 -static unsigned char tiny_twosuperior_bits[] = { - 0x02, 0x05, 0x04, 0x02, 0x07, 0x00, 0x00, 0x00, 0x00}; diff --git a/bitmaps/.svn/text-base/tiny_underscore.xbm.svn-base b/bitmaps/.svn/text-base/tiny_underscore.xbm.svn-base deleted file mode 100644 index b7f3f87..0000000 --- a/bitmaps/.svn/text-base/tiny_underscore.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_underscore_width 6 -#define tiny_underscore_height 3 -#define tiny_underscore_x_hot 1 -#define tiny_underscore_y_hot 0 -static unsigned char tiny_underscore_bits[] = { - 0x00, 0x00, 0x3f}; diff --git a/bitmaps/.svn/text-base/tiny_xsuperior.xbm.svn-base b/bitmaps/.svn/text-base/tiny_xsuperior.xbm.svn-base deleted file mode 100644 index fbd699f..0000000 --- a/bitmaps/.svn/text-base/tiny_xsuperior.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_xsuperior_width 5 -#define tiny_xsuperior_height 9 -#define tiny_xsuperior_x_hot 0 -#define tiny_xsuperior_y_hot 8 -static unsigned char tiny_xsuperior_bits[] = { - 0x12, 0x0c, 0x04, 0x0a, 0x09, 0x00, 0x00, 0x00, 0x00}; diff --git a/bitmaps/.svn/text-base/tiny_zero.xbm.svn-base b/bitmaps/.svn/text-base/tiny_zero.xbm.svn-base deleted file mode 100644 index be374ab..0000000 --- a/bitmaps/.svn/text-base/tiny_zero.xbm.svn-base +++ /dev/null @@ -1,6 +0,0 @@ -#define tiny_zero_width 5 -#define tiny_zero_height 7 -#define tiny_zero_x_hot 0 -#define tiny_zero_y_hot 6 -static unsigned char tiny_zero_bits[] = { - 0x06, 0x09, 0x09, 0x09, 0x09, 0x09, 0x06}; diff --git a/bitmaps/CVS/.svn/all-wcprops b/bitmaps/CVS/.svn/all-wcprops deleted file mode 100644 index 062cc84..0000000 --- a/bitmaps/CVS/.svn/all-wcprops +++ /dev/null @@ -1,23 +0,0 @@ -K 25 -svn:wc:ra_dav:version-url -V 36 -/p/x49gp/code/!svn/ver/1/bitmaps/CVS -END -Repository -K 25 -svn:wc:ra_dav:version-url -V 47 -/p/x49gp/code/!svn/ver/1/bitmaps/CVS/Repository -END -Root -K 25 -svn:wc:ra_dav:version-url -V 41 -/p/x49gp/code/!svn/ver/1/bitmaps/CVS/Root -END -Entries -K 25 -svn:wc:ra_dav:version-url -V 44 -/p/x49gp/code/!svn/ver/1/bitmaps/CVS/Entries -END diff --git a/bitmaps/CVS/.svn/entries b/bitmaps/CVS/.svn/entries deleted file mode 100644 index c0b5710..0000000 --- a/bitmaps/CVS/.svn/entries +++ /dev/null @@ -1,130 +0,0 @@ -10 - -dir -11 -http://svn.code.sf.net/p/x49gp/code/bitmaps/CVS -http://svn.code.sf.net/p/x49gp/code - - - -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - -481df3bd-3408-496c-b7de-451e46197bb5 - -Repository -file - - - - -2013-08-23T00:54:47.000000Z -2c17e51e27554afae683fcafbe9562e4 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -14 - -Root -file - - - - -2013-08-23T00:54:47.000000Z -f51b768066a9e7d88829b19678326fcd -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -60 - -Entries -file - - - - -2013-08-23T00:54:47.000000Z -156818d09a9c64a5b52e9ff57ab0b6f4 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -4370 - diff --git a/bitmaps/CVS/.svn/text-base/Entries.svn-base b/bitmaps/CVS/.svn/text-base/Entries.svn-base deleted file mode 100644 index e32251f..0000000 --- a/bitmaps/CVS/.svn/text-base/Entries.svn-base +++ /dev/null @@ -1,91 +0,0 @@ -/ann_alpha.xbm/1.4/Thu Dec 11 12:14:08 2008// -/ann_battery.xbm/1.4/Thu Dec 11 12:14:08 2008// -/ann_busy.xbm/1.4/Thu Dec 11 12:14:08 2008// -/ann_io.xbm/1.4/Thu Dec 11 12:14:08 2008// -/ann_left.xbm/1.4/Thu Dec 11 12:14:08 2008// -/ann_right.xbm/1.4/Thu Dec 11 12:14:08 2008// -/button_large.xbm/1.4/Thu Dec 11 12:14:08 2008// -/button_normal.xbm/1.4/Thu Dec 11 12:14:08 2008// -/button_round.pix/1.1/Wed Jul 12 11:30:39 2006// -/button_round.xbm/1.4/Thu Dec 11 12:14:08 2008// -/button_small.xbm/1.4/Thu Dec 11 12:14:08 2008// -/button_tiny.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_A.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_B.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_C.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_D.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_E.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_F.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_G.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_H.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_I.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_J.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_K.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_L.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_M.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_N.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_O.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_P.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_Q.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_R.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_S.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_T.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_U.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_V.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_W.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_X.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_Y.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_Z.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny__i.xbm/1.1/Thu Dec 11 12:19:15 2008// -/tiny_ampersand.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_arrowleft.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_arrowright.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_braceleft.xbm/1.5/Thu Dec 11 12:14:08 2008// -/tiny_braceright.xbm/1.5/Thu Dec 11 12:14:08 2008// -/tiny_bracketleft.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_bracketright.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_colon.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_comma.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_equal.xbm/1.5/Thu Dec 11 12:14:08 2008// -/tiny_greater.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_guillemotleft.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_guillemotright.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_hyphen.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_large_comma.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_less.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_math_arrowleft.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_math_arrowright.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_math_downarrowleft.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_math_downarrowright.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_math_e.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_math_equal.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_math_greater.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_math_greaterequal.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_math_infinity.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_math_integral.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_math_less.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_math_lessequal.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_math_notequal.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_math_numbersign.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_math_partialdiff.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_math_pi.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_math_radical.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_math_summation.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_math_x.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_math_y.xbm/1.5/Thu Dec 11 12:14:08 2008// -/tiny_notdef.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_numbersign.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_one.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_overscore.xbm/1.5/Thu Dec 11 12:14:08 2008// -/tiny_parenleft.xbm/1.5/Thu Dec 11 12:14:08 2008// -/tiny_parenright.xbm/1.5/Thu Dec 11 12:14:08 2008// -/tiny_period.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_quotedbl.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_slash.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_three.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_two.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_twosuperior.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_underscore.xbm/1.5/Thu Dec 11 12:14:08 2008// -/tiny_xsuperior.xbm/1.4/Thu Dec 11 12:14:08 2008// -/tiny_zero.xbm/1.4/Thu Dec 11 12:14:08 2008// -D diff --git a/bitmaps/CVS/.svn/text-base/Repository.svn-base b/bitmaps/CVS/.svn/text-base/Repository.svn-base deleted file mode 100644 index a01358d..0000000 --- a/bitmaps/CVS/.svn/text-base/Repository.svn-base +++ /dev/null @@ -1 +0,0 @@ -x49gp/bitmaps diff --git a/bitmaps/CVS/.svn/text-base/Root.svn-base b/bitmaps/CVS/.svn/text-base/Root.svn-base deleted file mode 100644 index 6f29e94..0000000 --- a/bitmaps/CVS/.svn/text-base/Root.svn-base +++ /dev/null @@ -1 +0,0 @@ -:pserver:anonymous@x49gp.cvs.sourceforge.net:/cvsroot/x49gp diff --git a/include/.svn/all-wcprops b/include/.svn/all-wcprops deleted file mode 100644 index 2fe3d60..0000000 --- a/include/.svn/all-wcprops +++ /dev/null @@ -1,113 +0,0 @@ -K 25 -svn:wc:ra_dav:version-url -V 33 -/p/x49gp/code/!svn/ver/10/include -END -block.h -K 25 -svn:wc:ra_dav:version-url -V 41 -/p/x49gp/code/!svn/ver/10/include/block.h -END -s3c2410_timer.h -K 25 -svn:wc:ra_dav:version-url -V 48 -/p/x49gp/code/!svn/ver/1/include/s3c2410_timer.h -END -s3c2410.h -K 25 -svn:wc:ra_dav:version-url -V 42 -/p/x49gp/code/!svn/ver/1/include/s3c2410.h -END -byteorder.h -K 25 -svn:wc:ra_dav:version-url -V 44 -/p/x49gp/code/!svn/ver/1/include/byteorder.h -END -bitmaps.h -K 25 -svn:wc:ra_dav:version-url -V 42 -/p/x49gp/code/!svn/ver/1/include/bitmaps.h -END -x49gp_types.h -K 25 -svn:wc:ra_dav:version-url -V 46 -/p/x49gp/code/!svn/ver/1/include/x49gp_types.h -END -bitmap_font.h -K 25 -svn:wc:ra_dav:version-url -V 46 -/p/x49gp/code/!svn/ver/1/include/bitmap_font.h -END -block_int.h -K 25 -svn:wc:ra_dav:version-url -V 45 -/p/x49gp/code/!svn/ver/10/include/block_int.h -END -symbol.h -K 25 -svn:wc:ra_dav:version-url -V 41 -/p/x49gp/code/!svn/ver/1/include/symbol.h -END -x49gp_ui.h -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/include/x49gp_ui.h -END -x49gp.h -K 25 -svn:wc:ra_dav:version-url -V 41 -/p/x49gp/code/!svn/ver/10/include/x49gp.h -END -s3c2410_power.h -K 25 -svn:wc:ra_dav:version-url -V 48 -/p/x49gp/code/!svn/ver/1/include/s3c2410_power.h -END -list.h -K 25 -svn:wc:ra_dav:version-url -V 40 -/p/x49gp/code/!svn/ver/10/include/list.h -END -x49gp_timer.h -K 25 -svn:wc:ra_dav:version-url -V 47 -/p/x49gp/code/!svn/ver/10/include/x49gp_timer.h -END -s3c2410_intc.h -K 25 -svn:wc:ra_dav:version-url -V 47 -/p/x49gp/code/!svn/ver/1/include/s3c2410_intc.h -END -saturn.h -K 25 -svn:wc:ra_dav:version-url -V 41 -/p/x49gp/code/!svn/ver/1/include/saturn.h -END -s3c2410_mmu.h -K 25 -svn:wc:ra_dav:version-url -V 46 -/p/x49gp/code/!svn/ver/1/include/s3c2410_mmu.h -END -glyphname.h -K 25 -svn:wc:ra_dav:version-url -V 44 -/p/x49gp/code/!svn/ver/1/include/glyphname.h -END diff --git a/include/.svn/entries b/include/.svn/entries deleted file mode 100644 index c7b820f..0000000 --- a/include/.svn/entries +++ /dev/null @@ -1,643 +0,0 @@ -10 - -dir -11 -http://svn.code.sf.net/p/x49gp/code/include -http://svn.code.sf.net/p/x49gp/code - - - -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - -481df3bd-3408-496c-b7de-451e46197bb5 - -block.h -file - - - - -2013-08-23T00:54:46.000000Z -724d77629c1c152eac647c68e3738115 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -6833 - -s3c2410_timer.h -file - - - - -2013-08-23T00:54:46.000000Z -f54b86fa985ffc88917da28c2a8ac118 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -1389 - -s3c2410.h -file - - - - -2013-08-23T00:54:46.000000Z -d3d2551d57134aef5991fc4342a4ecc6 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -11906 - -byteorder.h -file - - - - -2013-08-23T00:54:46.000000Z -b7749ae9c1359d8e43981ba94bdc5977 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -1981 - -bitmaps.h -file - - - - -2013-08-23T00:54:46.000000Z -f7f9b1755e8733d5d088311951eddc8e -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -462 - -x49gp_types.h -file - - - - -2013-08-23T00:54:46.000000Z -04fdff61e46ad293425cb4bbd17dc90d -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -484 - -bitmap_font.h -file - - - - -2013-08-23T00:54:46.000000Z -0fc4834669f0ab7ef08b150810c0ab95 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -772 - -block_int.h -file - - - - -2013-08-23T00:54:46.000000Z -e7a9a03638da2682a1c2d32d8af0fe58 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -4267 - -symbol.h -file - - - - -2013-08-23T00:54:46.000000Z -e3765ce8fad75a0f7af53e851dfc0f4b -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -1710 - -CVS -dir - -x49gp_ui.h -file - - - - -2013-08-23T00:54:46.000000Z -c0038310fddb0a91cbac539b61340f12 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -2224 - -x49gp.h -file - - - - -2013-08-23T00:54:46.000000Z -c6f8a2036694a0ee43da6c109ddaa239 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -3602 - -s3c2410_power.h -file - - - - -2013-08-23T00:54:46.000000Z -f82936ec6c6ddefbcb7184f8955f5b1e -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -759 - -list.h -file - - - - -2013-08-23T00:54:46.000000Z -58c07e25aacaaf9d4274bef65a77f470 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -18688 - -x49gp_timer.h -file - - - - -2013-08-23T00:54:46.000000Z -2500b1c34f6b949b3abcfbe1c1e4fbe6 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -818 - -saturn.h -file - - - - -2013-08-23T00:54:46.000000Z -fcd320a635f3f67bff402c3d28789e31 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -812 - -s3c2410_intc.h -file - - - - -2013-08-23T00:54:46.000000Z -58055caa3e8e564481a947e137e235a8 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -1678 - -s3c2410_mmu.h -file - - - - -2013-08-23T00:54:46.000000Z -9f8f0272ca3986e74b9b9b78ba4ef78d -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -660 - -glyphname.h -file - - - - -2013-08-23T00:54:46.000000Z -3a3fac3ab41ca7c03a2f2103517f4153 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -5982 - diff --git a/include/.svn/text-base/bitmap_font.h.svn-base b/include/.svn/text-base/bitmap_font.h.svn-base deleted file mode 100644 index ef99d6f..0000000 --- a/include/.svn/text-base/bitmap_font.h.svn-base +++ /dev/null @@ -1,37 +0,0 @@ -/* $Id: bitmap_font.h,v 1.5 2008/12/11 12:18:17 ecd Exp $ - */ - -#ifndef _X49GP_BITMAP_FONT_H -#define _X49GP_BITMAP_FONT_H 1 - -typedef struct { - const char *name; - int width; - int kern; - int ascent; - int descent; - const unsigned char *bits; -} bitmap_glyph_t; - -typedef struct { - int ascent; - int descent; - bitmap_glyph_t glyphs[]; -} bitmap_font_t; - -#define GLYPH(font, name) \ - { \ - #name, \ - font##_##name##_width - font##_##name##_x_hot, \ - -font##_##name##_x_hot, \ - font##_##name##_y_hot + 1, \ - font##_##name##_y_hot + 1 - font##_##name##_height, \ - font##_##name##_bits \ - } - -#define SPACE(name, width, kern) \ - { name, width, kern, 0, 0, NULL } - -extern const bitmap_font_t tiny_font; - -#endif /* !(_X49GP_BITMAP_FONT_H) */ diff --git a/include/.svn/text-base/bitmaps.h.svn-base b/include/.svn/text-base/bitmaps.h.svn-base deleted file mode 100644 index de8e25d..0000000 --- a/include/.svn/text-base/bitmaps.h.svn-base +++ /dev/null @@ -1,21 +0,0 @@ -/* $Id: bitmaps.h,v 1.9 2008/12/11 12:18:17 ecd Exp $ - */ - -#ifndef _X49GP_BITMAPS_H -#define _X49GP_BITMAPS_H 1 - -#include -#include -#include -#include -#include -#include - -#include -#include -#include -#include -#include -#include - -#endif /* !(_X49GP_BITMAPS_H) */ diff --git a/include/.svn/text-base/block.h.svn-base b/include/.svn/text-base/block.h.svn-base deleted file mode 100644 index e4c285a..0000000 --- a/include/.svn/text-base/block.h.svn-base +++ /dev/null @@ -1,187 +0,0 @@ -/* $Id: block.h,v 1.1 2008/12/11 12:18:17 ecd Exp $ - */ - -#ifndef BLOCK_H -#define BLOCK_H 1 - -#include - -#define BDRV_O_RDONLY 0x0000 -#define BDRV_O_RDWR 0x0002 -#define BDRV_O_ACCESS 0x0003 -#define BDRV_O_CREAT 0x0004 /* create an empty file */ -#define BDRV_O_SNAPSHOT 0x0008 /* open the file read only and save - writes in a snapshot */ -#define BDRV_O_FILE 0x0010 /* open as a raw file (do not try to - use a disk image format on top of - it (default for - bdrv_file_open()) */ - -#ifdef QEMU_OLD -typedef struct BlockDriverState BlockDriverState; -#endif -typedef struct BlockDriver BlockDriver; -typedef struct SnapshotInfo QEMUSnapshotInfo; -typedef struct BlockDriverInfo BlockDriverInfo; -typedef struct BlockDriverAIOCB BlockDriverAIOCB; -typedef void BlockDriverCompletionFunc(void *opaque, int ret); - -extern BlockDriver bdrv_raw; -extern BlockDriver bdrv_host_device; -extern BlockDriver bdrv_qcow; -extern BlockDriver bdrv_vvfat; - -void bdrv_init(void); -int bdrv_create(BlockDriver *drv, - const char *filename, int64_t size_in_sectors, - const char *backing_file, int flags); -BlockDriverState *bdrv_new(const char *device_name); -void bdrv_delete(BlockDriverState *bs); -int bdrv_file_open(BlockDriverState **pbs, const char *filename, int flags); -int bdrv_open(BlockDriverState *bs, const char *filename, int flags); - -int bdrv_read(BlockDriverState *bs, int64_t sector_num, - uint8_t *buf, int nb_sectors); -int bdrv_pread(BlockDriverState *bs, int64_t offset, - void *buf, int count); -int bdrv_pwrite(BlockDriverState *bs, int64_t offset, - const void *buf, int count); - -#ifdef QEMU_OLD -struct BlockDriver { - const char *format_name; - int instance_size; - int (*bdrv_probe)(const uint8_t *buf, int buf_size, const char *filename); - int (*bdrv_open)(BlockDriverState *bs, const char *filename, int flags); - int (*bdrv_read)(BlockDriverState *bs, int64_t sector_num, - uint8_t *buf, int nb_sectors); - int (*bdrv_write)(BlockDriverState *bs, int64_t sector_num, - const uint8_t *buf, int nb_sectors); - void (*bdrv_close)(BlockDriverState *bs); - int (*bdrv_create)(const char *filename, int64_t total_sectors, - const char *backing_file, int flags); - void (*bdrv_flush)(BlockDriverState *bs); - int (*bdrv_is_allocated)(BlockDriverState *bs, int64_t sector_num, - int nb_sectors, int *pnum); - int (*bdrv_set_key)(BlockDriverState *bs, const char *key); - int (*bdrv_make_empty)(BlockDriverState *bs); - /* aio */ - BlockDriverAIOCB *(*bdrv_aio_read)(BlockDriverState *bs, - int64_t sector_num, uint8_t *buf, int nb_sectors, - BlockDriverCompletionFunc *cb, void *opaque); - BlockDriverAIOCB *(*bdrv_aio_write)(BlockDriverState *bs, - int64_t sector_num, const uint8_t *buf, int nb_sectors, - BlockDriverCompletionFunc *cb, void *opaque); - void (*bdrv_aio_cancel)(BlockDriverAIOCB *acb); - int aiocb_size; - - const char *protocol_name; - int (*bdrv_pread)(BlockDriverState *bs, int64_t offset, - uint8_t *buf, int count); - int (*bdrv_pwrite)(BlockDriverState *bs, int64_t offset, - const uint8_t *buf, int count); - int (*bdrv_truncate)(BlockDriverState *bs, int64_t offset); - int64_t (*bdrv_getlength)(BlockDriverState *bs); - int (*bdrv_write_compressed)(BlockDriverState *bs, int64_t sector_num, - const uint8_t *buf, int nb_sectors); - - int (*bdrv_snapshot_create)(BlockDriverState *bs, - QEMUSnapshotInfo *sn_info); - int (*bdrv_snapshot_goto)(BlockDriverState *bs, - const char *snapshot_id); - int (*bdrv_snapshot_delete)(BlockDriverState *bs, const char *snapshot_id); - int (*bdrv_snapshot_list)(BlockDriverState *bs, - QEMUSnapshotInfo **psn_info); - int (*bdrv_get_info)(BlockDriverState *bs, BlockDriverInfo *bdi); - - /* removable device specific */ - int (*bdrv_is_inserted)(BlockDriverState *bs); - int (*bdrv_media_changed)(BlockDriverState *bs); - int (*bdrv_eject)(BlockDriverState *bs, int eject_flag); - int (*bdrv_set_locked)(BlockDriverState *bs, int locked); - - BlockDriverAIOCB *free_aiocb; - struct BlockDriver *next; -}; - -struct BlockDriverState { - int64_t total_sectors; /* if we are reading a disk image, give its - size in sectors */ - int read_only; /* if true, the media is read only */ - int removable; /* if true, the media can be removed */ - int locked; /* if true, the media cannot temporarily be ejected */ - int encrypted; /* if true, the media is encrypted */ - /* event callback when inserting/removing */ - void (*change_cb)(void *opaque); - void *change_opaque; - - BlockDriver *drv; /* NULL means no media */ - void *opaque; - - int boot_sector_enabled; - uint8_t boot_sector_data[512]; - - char filename[1024]; - char backing_file[1024]; /* if non zero, the image is a diff of - this file image */ - int is_temporary; - int media_changed; - - BlockDriverState *backing_hd; -// /* async read/write emulation */ -// -// void *sync_aiocb; - - /* NOTE: the following infos are only hints for real hardware - drivers. They are not used by the block driver */ - int cyls, heads, secs, translation; - int type; - char device_name[32]; - BlockDriverState *next; -}; - -void *qemu_malloc(size_t size); -void *qemu_mallocz(size_t size); -void qemu_free(void *ptr); - -void pstrcpy(char *buf, int buf_size, const char *str); -char *pstrcat(char *buf, int buf_size, const char *s); -int strstart(const char *str, const char *val, const char **ptr); -int stristart(const char *str, const char *val, const char **ptr); -#endif /* QEMU_OLD */ - -#ifndef QEMU_OLD -int bdrv_truncate(BlockDriverState *bs, int64_t offset); -int64_t bdrv_getlength(BlockDriverState *bs); -void bdrv_flush(BlockDriverState *bs); - -/* timers */ - -typedef struct QEMUClock QEMUClock; -typedef void QEMUTimerCB(void *opaque); - -/* The real time clock should be used only for stuff which does not - change the virtual machine state, as it is run even if the virtual - machine is stopped. The real time clock has a frequency of 1000 - Hz. */ -extern QEMUClock *rt_clock; - -int64_t qemu_get_clock(QEMUClock *clock); - -QEMUTimer *qemu_new_timer(QEMUClock *clock, QEMUTimerCB *cb, void *opaque); -void qemu_del_timer(QEMUTimer *ts); -void qemu_mod_timer(QEMUTimer *ts, int64_t expire_time); -int qemu_timer_pending(QEMUTimer *ts); - -extern int64_t ticks_per_sec; - -struct BlockDriverInfo { - /* in bytes, 0 if irrelevant */ - int cluster_size; - /* offset at which the VM state can be saved (0 if not possible) */ - int64_t vm_state_offset; -}; - -#endif - -#endif /* !(BLOCK_H) */ diff --git a/include/.svn/text-base/block_int.h.svn-base b/include/.svn/text-base/block_int.h.svn-base deleted file mode 100644 index 581679a..0000000 --- a/include/.svn/text-base/block_int.h.svn-base +++ /dev/null @@ -1,104 +0,0 @@ -/* - * QEMU System Emulator block driver - * - * Copyright (c) 2003 Fabrice Bellard - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ -#ifndef BLOCK_INT_H -#define BLOCK_INT_H - -struct BlockDriver { - const char *format_name; - int instance_size; - int (*bdrv_probe)(const uint8_t *buf, int buf_size, const char *filename); - int (*bdrv_open)(BlockDriverState *bs, const char *filename, int flags); - int (*bdrv_read)(BlockDriverState *bs, int64_t sector_num, - uint8_t *buf, int nb_sectors); - int (*bdrv_write)(BlockDriverState *bs, int64_t sector_num, - const uint8_t *buf, int nb_sectors); - void (*bdrv_close)(BlockDriverState *bs); - int (*bdrv_create)(const char *filename, int64_t total_sectors, - const char *backing_file, int flags); - void (*bdrv_flush)(BlockDriverState *bs); - int (*bdrv_is_allocated)(BlockDriverState *bs, int64_t sector_num, - int nb_sectors, int *pnum); - int (*bdrv_set_key)(BlockDriverState *bs, const char *key); - int (*bdrv_make_empty)(BlockDriverState *bs); - - const char *protocol_name; - int (*bdrv_pread)(BlockDriverState *bs, int64_t offset, - uint8_t *buf, int count); - int (*bdrv_pwrite)(BlockDriverState *bs, int64_t offset, - const uint8_t *buf, int count); - int (*bdrv_truncate)(BlockDriverState *bs, int64_t offset); - int64_t (*bdrv_getlength)(BlockDriverState *bs); - int (*bdrv_write_compressed)(BlockDriverState *bs, int64_t sector_num, - const uint8_t *buf, int nb_sectors); - - int (*bdrv_get_info)(BlockDriverState *bs, BlockDriverInfo *bdi); - - /* removable device specific */ - int (*bdrv_is_inserted)(BlockDriverState *bs); - int (*bdrv_media_changed)(BlockDriverState *bs); - int (*bdrv_eject)(BlockDriverState *bs, int eject_flag); - int (*bdrv_set_locked)(BlockDriverState *bs, int locked); - - struct BlockDriver *next; -}; - -struct BlockDriverState { - int64_t total_sectors; /* if we are reading a disk image, give its - size in sectors */ - int read_only; /* if true, the media is read only */ - int removable; /* if true, the media can be removed */ - int locked; /* if true, the media cannot temporarily be ejected */ - int encrypted; /* if true, the media is encrypted */ - /* event callback when inserting/removing */ - void (*change_cb)(void *opaque); - void *change_opaque; - - BlockDriver *drv; /* NULL means no media */ - void *opaque; - - int boot_sector_enabled; - uint8_t boot_sector_data[512]; - - char filename[1024]; - char backing_file[1024]; /* if non zero, the image is a diff of - this file image */ - int is_temporary; - int media_changed; - - BlockDriverState *backing_hd; - /* async read/write emulation */ - - void *sync_aiocb; - - /* NOTE: the following infos are only hints for real hardware - drivers. They are not used by the block driver */ - int cyls, heads, secs, translation; - int type; - char device_name[32]; - BlockDriverState *next; -}; - -void get_tmp_filename(char *filename, int size); - -#endif /* BLOCK_INT_H */ diff --git a/include/.svn/text-base/byteorder.h.svn-base b/include/.svn/text-base/byteorder.h.svn-base deleted file mode 100644 index 72fb035..0000000 --- a/include/.svn/text-base/byteorder.h.svn-base +++ /dev/null @@ -1,91 +0,0 @@ -/* $Id: byteorder.h,v 1.5 2008/12/11 12:18:17 ecd Exp $ - */ - -#ifndef _X49GP_BYTEORDER_H -#define _X49GP_BYTEORDER_H 1 - -#include - -static __inline__ uint16_t swab16(uint16_t x) -{ - return ((x & 0xff00) >> 8) | - ((x & 0x00ff) << 8); -} - -static __inline__ uint32_t swab32(uint32_t x) -{ - return ((x & 0xff000000) >> 24) | - ((x & 0x00ff0000) >> 8) | - ((x & 0x0000ff00) << 8) | - ((x & 0x000000ff) << 24); -} - -#ifdef __sparc__ - -#define ASI_PL 0x88 /* Primary, implicit, little endian. */ - -static __inline__ uint16_t __load_le16(const uint16_t *p) -{ - uint16_t x; - - __asm__ __volatile__ ("lduha [%1] %2, %0" - : "=r" (x) - : "r" (p), "i" (ASI_PL)); - return x; -} - -static __inline__ uint32_t __load_le32(const uint32_t *p) -{ - uint32_t x; - - __asm__ __volatile__ ("lduwa [%1] %2, %0" - : "=r" (x) - : "r" (p), "i" (ASI_PL)); - return x; -} - -static __inline__ void __store_le16(uint16_t *p, uint16_t x) -{ - __asm__ __volatile__ ("stha %0, [%1] %2" - : /* no outputs */ - : "r" (x), "r" (p), "i" (ASI_PL)); -} - -static __inline__ void __store_le32(uint32_t *p, uint32_t x) -{ - __asm__ __volatile__ ("stwa %0, [%1] %2" - : /* no outputs */ - : "r" (x), "r" (p), "i" (ASI_PL)); -} - -#endif /* __sparc__ */ - -#if __BYTE_ORDER == __LITTLE_ENDIAN - -#define le16_to_cpu(x) (x) -#define cpu_to_le16(x) (x) -#define le32_to_cpu(x) (x) -#define cpu_to_le32(x) (x) - -#define load_le16(p) (*(p)) -#define store_le16(p, x) (*(p) = (x)) -#define load_le32(p) (*(p)) -#define store_le32(p, x) (*(p) = (x)) - -#elif __BYTE_ORDER == __BIG_ENDIAN - -#define le16_to_cpu(x) swab16(x) -#define cpu_to_le16(x) swab16(x) -#define le32_to_cpu(x) swab32(x) -#define cpu_to_le32(x) swab32(x) - -#define load_le16(p) __load_le16(p) -#define store_le16(p, x) __store_le16(p, x) -#define load_le32(p) __load_le32(p) -#define store_le32(p, x) __store_le32(p, x) - -#else -#error "Cannot determine host byteorder" -#endif - -#endif /* !(_X49GP_BYTEORDER_H) */ diff --git a/include/.svn/text-base/glyphname.h.svn-base b/include/.svn/text-base/glyphname.h.svn-base deleted file mode 100644 index 787d8e9..0000000 --- a/include/.svn/text-base/glyphname.h.svn-base +++ /dev/null @@ -1,238 +0,0 @@ -/* $Id: glyphname.h,v 1.3 2008/12/11 12:18:17 ecd Exp $ - */ - -#ifndef _X49GP_GLYPHNAME_H -#define _X49GP_GLYPHNAME_H 1 - -typedef struct { - const char *name; - gunichar unichar; -} x49gp_glyph_t; - -static const x49gp_glyph_t x49gp_glyphs[] = -{ - { "exclamdown", 0x00a1 }, - { "cent", 0x00a2 }, - { "sterling", 0x00a3 }, - { "fraction", 0x2044 }, - { "yen", 0x00a5 }, - { "florin", 0x0192 }, - { "section", 0x00a7 }, - { "currency", 0x00a4 }, - { "quotesingle", 0x0027 }, - { "quotedblleft", 0x201c }, - { "guillemotleft", 0x00ab }, - { "guilsinglleft", 0x2039 }, - { "guilsinglright", 0x203a }, - { "fi", 0xfb01 }, - { "fl", 0xfb02 }, - { "endash", 0x2013 }, - { "dagger", 0x2020 }, - { "daggerdbl", 0x2021 }, - { "periodcentered", 0x00b7 }, - { "paragraph", 0x00b6 }, - { "bullet", 0x2022 }, - { "quotesinglbase", 0x201a }, - { "quotedblbase", 0x201e }, - { "quotedblright", 0x201d }, - { "guillemotright", 0x00bb }, - { "ellipsis", 0x2026 }, - { "perthousand", 0x2030 }, - { "questiondown", 0x00bf }, - { "grave", 0x0060 }, - { "acute", 0x00b4 }, - { "circumflex", 0x02c6 }, - { "tilde", 0x02dc }, - { "macron", 0x00af }, - { "breve", 0x02d8 }, - { "dotaccent", 0x02d9 }, - { "dieresis", 0x00a8 }, - { "ring", 0x02da }, - { "cedilla", 0x00b8 }, - { "hungarumlaut", 0x02dd }, - { "ogonek", 0x02db }, - { "caron", 0x02c7 }, - { "emdash", 0x2014 }, - { "AE", 0x00c6 }, - { "ordfeminine", 0x00aa }, - { "Lslash", 0x0141 }, - { "Oslash", 0x00d8 }, - { "OE", 0x0152 }, - { "ordmasculine", 0x00ba }, - { "ae", 0x00e6 }, - { "dotlessi", 0x0131 }, - { "lslash", 0x0142 }, - { "oslash", 0x00f8 }, - { "oe", 0x0153 }, - { "germandbls", 0x00df }, - { "Udieresis", 0x00dc }, - { "Uacute", 0x00da }, - { "Scedilla", 0x015e }, - { "Tcaron", 0x0164 }, - { "Scaron", 0x0160 }, - { "Rcaron", 0x0158 }, - { "Racute", 0x0154 }, - { "Sacute", 0x015a }, - { "Otilde", 0x00d5 }, - { "ucircumflex", 0x00fb }, - { "Ohungarumlaut", 0x0150 }, - { "Uhungarumlaut", 0x0170 }, - { "Yacute", 0x00dd }, - { "Eth", 0x00d0 }, - { "Dcroat", 0x0110 }, - { "Zacute", 0x0179 }, - { "Uring", 0x016e }, - { "gbreve", 0x011f }, - { "eogonek", 0x0119 }, - { "edotaccent", 0x0117 }, - { "ecaron", 0x011b }, - { "Ugrave", 0x00d9 }, - { "Thorn", 0x00de }, - { "eacute", 0x00e9 }, - { "edieresis", 0x00eb }, - { "dcaron", 0x010f }, - { "ccedilla", 0x00e7 }, - { "ccaron", 0x010d }, - { "cacute", 0x0107 }, - { "aogonek", 0x0105 }, - { "aring", 0x00e5 }, - { "atilde", 0x00e3 }, - { "abreve", 0x0103 }, - { "egrave", 0x00e8 }, - { "agrave", 0x00e0 }, - { "aacute", 0x00e1 }, - { "adieresis", 0x00e4 }, - { "Uogonek", 0x0172 }, - { "ugrave", 0x00f9 }, - { "uacute", 0x00fa }, - { "udieresis", 0x00fc }, - { "tcaron", 0x0165 }, - { "scommaaccent", 0x0219 }, - { "Zcaron", 0x017d }, - { "ecircumflex", 0x00ea }, - { "Ucircumflex", 0x00db }, - { "acircumflex", 0x00e2 }, - { "Zdotaccent", 0x017b }, - { "scaron", 0x0161 }, - { "Amacron", 0x0100 }, - { "sacute", 0x015b }, - { "Tcommaaccent", 0x0162 }, - { "Ydieresis", 0x0178 }, - { "thorn", 0x00fe }, - { "Emacron", 0x0112 }, - { "Ograve", 0x00d2 }, - { "Oacute", 0x00d3 }, - { "Odieresis", 0x00d6 }, - { "Ntilde", 0x00d1 }, - { "Ncaron", 0x0147 }, - { "Nacute", 0x0143 }, - { "Lcaron", 0x013d }, - { "Lacute", 0x0139 }, - { "Idotaccent", 0x0130 }, - { "racute", 0x0155 }, - { "Icircumflex", 0x00ce }, - { "ohungarumlaut", 0x0151 }, - { "otilde", 0x00f5 }, - { "Euro", 0x20ac }, - { "ocircumflex", 0x00f4 }, - { "onesuperior", 0x00b9 }, - { "twosuperior", 0x00b2 }, - { "threesuperior", 0x00b3 }, - { "Igrave", 0x00cc }, - { "Iacute", 0x00cd }, - { "Imacron", 0x012a }, - { "Iogonek", 0x012e }, - { "Idieresis", 0x00cf }, - { "Gbreve", 0x011e }, - { "Umacron", 0x016a }, - { "Kcommaaccent", 0x0136 }, - { "ograve", 0x00f2 }, - { "Scommaaccent", 0x0218 }, - { "Eogonek", 0x0118 }, - { "oacute", 0x00f3 }, - { "Edotaccent", 0x0116 }, - { "iogonek", 0x012f }, - { "gcommaaccent", 0x0123 }, - { "odieresis", 0x00f6 }, - { "ntilde", 0x00f1 }, - { "ncaron", 0x0148 }, - { "Ecaron", 0x011a }, - { "Ecircumflex", 0x00ca }, - { "scedilla", 0x015f }, - { "rcaron", 0x0159 }, - { "Egrave", 0x00c8 }, - { "Eacute", 0x00c9 }, - { "Gcommaaccent", 0x0122 }, - { "Rcommaaccent", 0x0156 }, - { "Edieresis", 0x00cb }, - { "nacute", 0x0144 }, - { "uogonek", 0x0173 }, - { "umacron", 0x016b }, - { "Dcaron", 0x010e }, - { "lcaron", 0x013e }, - { "Ccaron", 0x010c }, - { "Cacute", 0x0106 }, - { "Ccedilla", 0x00c7 }, - { "degree", 0x00b0 }, - { "Aogonek", 0x0104 }, - { "minus", 0x2212 }, - { "multiply", 0x00d7 }, - { "divide", 0x00f7 }, - { "Aring", 0x00c5 }, - { "trademark", 0x2122 }, - { "rcommaaccent", 0x0157 }, - { "lacute", 0x013a }, - { "omacron", 0x014d }, - { "Atilde", 0x00c3 }, - { "icircumflex", 0x00ee }, - { "igrave", 0x00ec }, - { "ncommaaccent", 0x0146 }, - { "lcommaaccent", 0x013c }, - { "plusminus", 0x00b1 }, - { "onehalf", 0x00bd }, - { "onequarter", 0x00bc }, - { "threequarters", 0x00be }, - { "iacute", 0x00ed }, - { "Abreve", 0x0102 }, - { "kcommaaccent", 0x0137 }, - { "Omacron", 0x014c }, - { "imacron", 0x012b }, - { "emacron", 0x0113 }, - { "amacron", 0x0101 }, - { "tcommaaccent", 0x0163 }, - { "ydieresis", 0x00ff }, - { "zdotaccent", 0x017c }, - { "zcaron", 0x017e }, - { "zacute", 0x017a }, - { "yacute", 0x00fd }, - { "uhungarumlaut", 0x0171 }, - { "eth", 0x00f0 }, - { "uring", 0x016f }, - { "Ocircumflex", 0x00d4 }, - { "commaaccent", 0xf6c3 }, - { "copyright", 0x00a9 }, - { "registered", 0x00ae }, - { "Acircumflex", 0x00c2 }, - { "idieresis", 0x00ef }, - { "lozenge", 0x25ca }, - { "Delta", 0x2206 }, - { "notequal", 0x2260 }, - { "radical", 0x221a }, - { "Agrave", 0x00c0 }, - { "Aacute", 0x00c1 }, - { "lessequal", 0x2264 }, - { "greaterequal", 0x2265 }, - { "logicalnot", 0x00ac }, - { "summation", 0x2211 }, - { "partialdiff", 0x2202 }, - { "Ncommaaccent", 0x0145 }, - { "dcroat", 0x0111 }, - { "brokenbar", 0x00a6 }, - { "Lcommaaccent", 0x013b }, - { "Adieresis", 0x00c4 }, - { "mu", 0x00b5 } -}; - -#define NR_GLYPHNAMES (sizeof(x49gp_glyphs) / sizeof(x49gp_glyphs[0])) - -#endif /* !(_X49GP_GLYPHNAME_H) */ diff --git a/include/.svn/text-base/list.h.svn-base b/include/.svn/text-base/list.h.svn-base deleted file mode 100644 index ccf9148..0000000 --- a/include/.svn/text-base/list.h.svn-base +++ /dev/null @@ -1,600 +0,0 @@ -#ifndef _LINUX_LIST_H -#define _LINUX_LIST_H - -#include - -static inline void prefetch(const void *x) {;} - -#ifndef offsetof -#define offsetof(TYPE, MEMBER) ((size_t) &((TYPE *)0)->MEMBER) -#endif - -#ifdef QEMU_OLD -/** - * container_of - cast a member of a structure out to the containing structure - * - * @ptr: the pointer to the member. - * @type: the type of the container struct this is embedded in. - * @member: the name of the member within the struct. - * - */ -#define container_of(ptr, type, member) ({ \ - const typeof( ((type *)0)->member ) *__mptr = (ptr); \ - (type *)( (char *)__mptr - offsetof(type,member) );}) -#endif - -/* - * These are non-NULL pointers that will result in page faults - * under normal circumstances, used to verify that nobody uses - * non-initialized list entries. - */ -#define LIST_POISON1 ((void *) 0x00100100) -#define LIST_POISON2 ((void *) 0x00200200) - -/* - * Simple doubly linked list implementation. - * - * Some of the internal functions ("__xxx") are useful when - * manipulating whole lists rather than single entries, as - * sometimes we already know the next/prev entries and we can - * generate better code by using them directly rather than - * using the generic single-entry routines. - */ - -struct list_head { - struct list_head *next, *prev; -}; - -#define LIST_HEAD_INIT(name) { &(name), &(name) } - -#define LIST_HEAD(name) \ - struct list_head name = LIST_HEAD_INIT(name) - -#define INIT_LIST_HEAD(ptr) do { \ - (ptr)->next = (ptr); (ptr)->prev = (ptr); \ -} while (0) - -/* - * Insert a new entry between two known consecutive entries. - * - * This is only for internal list manipulation where we know - * the prev/next entries already! - */ -static inline void __list_add(struct list_head *new, - struct list_head *prev, - struct list_head *next) -{ - next->prev = new; - new->next = next; - new->prev = prev; - prev->next = new; -} - -/** - * list_add - add a new entry - * @new: new entry to be added - * @head: list head to add it after - * - * Insert a new entry after the specified head. - * This is good for implementing stacks. - */ -static inline void list_add(struct list_head *new, struct list_head *head) -{ - __list_add(new, head, head->next); -} - -/** - * list_add_tail - add a new entry - * @new: new entry to be added - * @head: list head to add it before - * - * Insert a new entry before the specified head. - * This is useful for implementing queues. - */ -static inline void list_add_tail(struct list_head *new, struct list_head *head) -{ - __list_add(new, head->prev, head); -} - -/* - * Delete a list entry by making the prev/next entries - * point to each other. - * - * This is only for internal list manipulation where we know - * the prev/next entries already! - */ -static inline void __list_del(struct list_head * prev, struct list_head * next) -{ - next->prev = prev; - prev->next = next; -} - -/** - * list_del - deletes entry from list. - * @entry: the element to delete from the list. - * Note: list_empty on entry does not return true after this, the entry is - * in an undefined state. - */ -static inline void list_del(struct list_head *entry) -{ - __list_del(entry->prev, entry->next); - entry->next = LIST_POISON1; - entry->prev = LIST_POISON2; -} - -/** - * list_del_init - deletes entry from list and reinitialize it. - * @entry: the element to delete from the list. - */ -static inline void list_del_init(struct list_head *entry) -{ - __list_del(entry->prev, entry->next); - INIT_LIST_HEAD(entry); -} - -/** - * list_move - delete from one list and add as another's head - * @list: the entry to move - * @head: the head that will precede our entry - */ -static inline void list_move(struct list_head *list, struct list_head *head) -{ - __list_del(list->prev, list->next); - list_add(list, head); -} - -/** - * list_move_tail - delete from one list and add as another's tail - * @list: the entry to move - * @head: the head that will follow our entry - */ -static inline void list_move_tail(struct list_head *list, - struct list_head *head) -{ - __list_del(list->prev, list->next); - list_add_tail(list, head); -} - -/** - * list_empty - tests whether a list is empty - * @head: the list to test. - */ -static inline int list_empty(const struct list_head *head) -{ - return head->next == head; -} - -/** - * list_empty_careful - tests whether a list is - * empty _and_ checks that no other CPU might be - * in the process of still modifying either member - * - * NOTE: using list_empty_careful() without synchronization - * can only be safe if the only activity that can happen - * to the list entry is list_del_init(). Eg. it cannot be used - * if another CPU could re-list_add() it. - * - * @head: the list to test. - */ -static inline int list_empty_careful(const struct list_head *head) -{ - struct list_head *next = head->next; - return (next == head) && (next == head->prev); -} - -static inline void __list_splice(struct list_head *list, - struct list_head *head) -{ - struct list_head *first = list->next; - struct list_head *last = list->prev; - struct list_head *at = head->next; - - first->prev = head; - head->next = first; - - last->next = at; - at->prev = last; -} - -/** - * list_splice - join two lists - * @list: the new list to add. - * @head: the place to add it in the first list. - */ -static inline void list_splice(struct list_head *list, struct list_head *head) -{ - if (!list_empty(list)) - __list_splice(list, head); -} - -/** - * list_splice_init - join two lists and reinitialise the emptied list. - * @list: the new list to add. - * @head: the place to add it in the first list. - * - * The list at @list is reinitialised - */ -static inline void list_splice_init(struct list_head *list, - struct list_head *head) -{ - if (!list_empty(list)) { - __list_splice(list, head); - INIT_LIST_HEAD(list); - } -} - -/** - * list_entry - get the struct for this entry - * @ptr: the &struct list_head pointer. - * @type: the type of the struct this is embedded in. - * @member: the name of the list_struct within the struct. - */ -#define list_entry(ptr, type, member) \ - container_of(ptr, type, member) - -/** - * list_for_each - iterate over a list - * @pos: the &struct list_head to use as a loop counter. - * @head: the head for your list. - */ -#define list_for_each(pos, head) \ - for (pos = (head)->next; prefetch(pos->next), pos != (head); \ - pos = pos->next) - -/** - * __list_for_each - iterate over a list - * @pos: the &struct list_head to use as a loop counter. - * @head: the head for your list. - * - * This variant differs from list_for_each() in that it's the - * simplest possible list iteration code, no prefetching is done. - * Use this for code that knows the list to be very short (empty - * or 1 entry) most of the time. - */ -#define __list_for_each(pos, head) \ - for (pos = (head)->next; pos != (head); pos = pos->next) - -/** - * list_for_each_prev - iterate over a list backwards - * @pos: the &struct list_head to use as a loop counter. - * @head: the head for your list. - */ -#define list_for_each_prev(pos, head) \ - for (pos = (head)->prev; prefetch(pos->prev), pos != (head); \ - pos = pos->prev) - -/** - * list_for_each_safe - iterate over a list safe against removal of list entry - * @pos: the &struct list_head to use as a loop counter. - * @n: another &struct list_head to use as temporary storage - * @head: the head for your list. - */ -#define list_for_each_safe(pos, n, head) \ - for (pos = (head)->next, n = pos->next; pos != (head); \ - pos = n, n = pos->next) - -/** - * list_for_each_entry - iterate over list of given type - * @pos: the type * to use as a loop counter. - * @head: the head for your list. - * @member: the name of the list_struct within the struct. - */ -#define list_for_each_entry(pos, head, member) \ - for (pos = list_entry((head)->next, typeof(*pos), member); \ - prefetch(pos->member.next), &pos->member != (head); \ - pos = list_entry(pos->member.next, typeof(*pos), member)) - -/** - * list_for_each_entry_reverse - iterate backwards over list of given type. - * @pos: the type * to use as a loop counter. - * @head: the head for your list. - * @member: the name of the list_struct within the struct. - */ -#define list_for_each_entry_reverse(pos, head, member) \ - for (pos = list_entry((head)->prev, typeof(*pos), member); \ - prefetch(pos->member.prev), &pos->member != (head); \ - pos = list_entry(pos->member.prev, typeof(*pos), member)) - -/** - * list_prepare_entry - prepare a pos entry for use as a start point in - * list_for_each_entry_continue - * @pos: the type * to use as a start point - * @head: the head of the list - * @member: the name of the list_struct within the struct. - */ -#define list_prepare_entry(pos, head, member) \ - ((pos) ? : list_entry(head, typeof(*pos), member)) - -/** - * list_for_each_entry_continue - iterate over list of given type - * continuing after existing point - * @pos: the type * to use as a loop counter. - * @head: the head for your list. - * @member: the name of the list_struct within the struct. - */ -#define list_for_each_entry_continue(pos, head, member) \ - for (pos = list_entry(pos->member.next, typeof(*pos), member); \ - prefetch(pos->member.next), &pos->member != (head); \ - pos = list_entry(pos->member.next, typeof(*pos), member)) - -/** - * list_for_each_entry_safe - iterate over list of given type safe against removal of list entry - * @pos: the type * to use as a loop counter. - * @n: another type * to use as temporary storage - * @head: the head for your list. - * @member: the name of the list_struct within the struct. - */ -#define list_for_each_entry_safe(pos, n, head, member) \ - for (pos = list_entry((head)->next, typeof(*pos), member), \ - n = list_entry(pos->member.next, typeof(*pos), member); \ - &pos->member != (head); \ - pos = n, n = list_entry(n->member.next, typeof(*n), member)) - -/** - * list_for_each_entry_safe_reverse - iterate backwards over list of given type safe against removal of list entry. - * @pos: the type * to use as a loop counter. - * @n: another type * to use as temporary storage - * @head: the head for your list. - * @member: the name of the list_struct within the struct. - */ -#define list_for_each_entry_safe_reverse(pos, n, head, member) \ - for (pos = list_entry((head)->prev, typeof(*pos), member), \ - n = list_entry(pos->member.prev, typeof(*pos), member); \ - prefetch(pos->member.prev), &pos->member != (head); \ - pos = n, n = list_entry(n->member.prev, typeof(*n), member)) - -/** - * list_for_each_rcu - iterate over an rcu-protected list - * @pos: the &struct list_head to use as a loop counter. - * @head: the head for your list. - * - * This list-traversal primitive may safely run concurrently with - * the _rcu list-mutation primitives such as list_add_rcu() - * as long as the traversal is guarded by rcu_read_lock(). - */ -#define list_for_each_rcu(pos, head) \ - for (pos = (head)->next; prefetch(pos->next), pos != (head); \ - pos = rcu_dereference(pos->next)) - -#define __list_for_each_rcu(pos, head) \ - for (pos = (head)->next; pos != (head); \ - pos = rcu_dereference(pos->next)) - -/** - * list_for_each_safe_rcu - iterate over an rcu-protected list safe - * against removal of list entry - * @pos: the &struct list_head to use as a loop counter. - * @n: another &struct list_head to use as temporary storage - * @head: the head for your list. - * - * This list-traversal primitive may safely run concurrently with - * the _rcu list-mutation primitives such as list_add_rcu() - * as long as the traversal is guarded by rcu_read_lock(). - */ -#define list_for_each_safe_rcu(pos, n, head) \ - for (pos = (head)->next, n = pos->next; pos != (head); \ - pos = rcu_dereference(n), n = pos->next) - -/** - * list_for_each_entry_rcu - iterate over rcu list of given type - * @pos: the type * to use as a loop counter. - * @head: the head for your list. - * @member: the name of the list_struct within the struct. - * - * This list-traversal primitive may safely run concurrently with - * the _rcu list-mutation primitives such as list_add_rcu() - * as long as the traversal is guarded by rcu_read_lock(). - */ -#define list_for_each_entry_rcu(pos, head, member) \ - for (pos = list_entry((head)->next, typeof(*pos), member); \ - prefetch(pos->member.next), &pos->member != (head); \ - pos = rcu_dereference(list_entry(pos->member.next, \ - typeof(*pos), member))) - - -/** - * list_for_each_continue_rcu - iterate over an rcu-protected list - * continuing after existing point. - * @pos: the &struct list_head to use as a loop counter. - * @head: the head for your list. - * - * This list-traversal primitive may safely run concurrently with - * the _rcu list-mutation primitives such as list_add_rcu() - * as long as the traversal is guarded by rcu_read_lock(). - */ -#define list_for_each_continue_rcu(pos, head) \ - for ((pos) = (pos)->next; prefetch((pos)->next), (pos) != (head); \ - (pos) = rcu_dereference((pos)->next)) - -/* - * Double linked lists with a single pointer list head. - * Mostly useful for hash tables where the two pointer list head is - * too wasteful. - * You lose the ability to access the tail in O(1). - */ - -struct hlist_head { - struct hlist_node *first; -}; - -struct hlist_node { - struct hlist_node *next, **pprev; -}; - -#define HLIST_HEAD_INIT { .first = NULL } -#define HLIST_HEAD(name) struct hlist_head name = { .first = NULL } -#define INIT_HLIST_HEAD(ptr) ((ptr)->first = NULL) -#define INIT_HLIST_NODE(ptr) ((ptr)->next = NULL, (ptr)->pprev = NULL) - -static inline int hlist_unhashed(const struct hlist_node *h) -{ - return !h->pprev; -} - -static inline int hlist_empty(const struct hlist_head *h) -{ - return !h->first; -} - -static inline void __hlist_del(struct hlist_node *n) -{ - struct hlist_node *next = n->next; - struct hlist_node **pprev = n->pprev; - *pprev = next; - if (next) - next->pprev = pprev; -} - -static inline void hlist_del(struct hlist_node *n) -{ - __hlist_del(n); - n->next = LIST_POISON1; - n->pprev = LIST_POISON2; -} - -/** - * hlist_del_rcu - deletes entry from hash list without re-initialization - * @n: the element to delete from the hash list. - * - * Note: list_unhashed() on entry does not return true after this, - * the entry is in an undefined state. It is useful for RCU based - * lockfree traversal. - * - * In particular, it means that we can not poison the forward - * pointers that may still be used for walking the hash list. - * - * The caller must take whatever precautions are necessary - * (such as holding appropriate locks) to avoid racing - * with another list-mutation primitive, such as hlist_add_head_rcu() - * or hlist_del_rcu(), running on this same list. - * However, it is perfectly legal to run concurrently with - * the _rcu list-traversal primitives, such as - * hlist_for_each_entry(). - */ -static inline void hlist_del_rcu(struct hlist_node *n) -{ - __hlist_del(n); - n->pprev = LIST_POISON2; -} - -static inline void hlist_del_init(struct hlist_node *n) -{ - if (n->pprev) { - __hlist_del(n); - INIT_HLIST_NODE(n); - } -} - -static inline void hlist_add_head(struct hlist_node *n, struct hlist_head *h) -{ - struct hlist_node *first = h->first; - n->next = first; - if (first) - first->pprev = &n->next; - h->first = n; - n->pprev = &h->first; -} - -/* next must be != NULL */ -static inline void hlist_add_before(struct hlist_node *n, - struct hlist_node *next) -{ - n->pprev = next->pprev; - n->next = next; - next->pprev = &n->next; - *(n->pprev) = n; -} - -static inline void hlist_add_after(struct hlist_node *n, - struct hlist_node *next) -{ - next->next = n->next; - n->next = next; - next->pprev = &n->next; - - if(next->next) - next->next->pprev = &next->next; -} - -#define hlist_entry(ptr, type, member) container_of(ptr,type,member) - -#define hlist_for_each(pos, head) \ - for (pos = (head)->first; pos && ({ prefetch(pos->next); 1; }); \ - pos = pos->next) - -#define hlist_for_each_safe(pos, n, head) \ - for (pos = (head)->first; pos && ({ n = pos->next; 1; }); \ - pos = n) - -#define hlist_for_each_rcu(pos, head) \ - for ((pos) = (head)->first; pos && ({ prefetch((pos)->next); 1; }); \ - (pos) = rcu_dereference((pos)->next)) - -/** - * hlist_for_each_entry - iterate over list of given type - * @tpos: the type * to use as a loop counter. - * @pos: the &struct hlist_node to use as a loop counter. - * @head: the head for your list. - * @member: the name of the hlist_node within the struct. - */ -#define hlist_for_each_entry(tpos, pos, head, member) \ - for (pos = (head)->first; \ - pos && ({ prefetch(pos->next); 1;}) && \ - ({ tpos = hlist_entry(pos, typeof(*tpos), member); 1;}); \ - pos = pos->next) - -/** - * hlist_for_each_entry_continue - iterate over a hlist continuing after existing point - * @tpos: the type * to use as a loop counter. - * @pos: the &struct hlist_node to use as a loop counter. - * @member: the name of the hlist_node within the struct. - */ -#define hlist_for_each_entry_continue(tpos, pos, member) \ - for (pos = (pos)->next; \ - pos && ({ prefetch(pos->next); 1;}) && \ - ({ tpos = hlist_entry(pos, typeof(*tpos), member); 1;}); \ - pos = pos->next) - -/** - * hlist_for_each_entry_from - iterate over a hlist continuing from existing point - * @tpos: the type * to use as a loop counter. - * @pos: the &struct hlist_node to use as a loop counter. - * @member: the name of the hlist_node within the struct. - */ -#define hlist_for_each_entry_from(tpos, pos, member) \ - for (; pos && ({ prefetch(pos->next); 1;}) && \ - ({ tpos = hlist_entry(pos, typeof(*tpos), member); 1;}); \ - pos = pos->next) - -/** - * hlist_for_each_entry_safe - iterate over list of given type safe against removal of list entry - * @tpos: the type * to use as a loop counter. - * @pos: the &struct hlist_node to use as a loop counter. - * @n: another &struct hlist_node to use as temporary storage - * @head: the head for your list. - * @member: the name of the hlist_node within the struct. - */ -#define hlist_for_each_entry_safe(tpos, pos, n, head, member) \ - for (pos = (head)->first; \ - pos && ({ n = pos->next; 1; }) && \ - ({ tpos = hlist_entry(pos, typeof(*tpos), member); 1;}); \ - pos = n) - -/** - * hlist_for_each_entry_rcu - iterate over rcu list of given type - * @pos: the type * to use as a loop counter. - * @pos: the &struct hlist_node to use as a loop counter. - * @head: the head for your list. - * @member: the name of the hlist_node within the struct. - * - * This list-traversal primitive may safely run concurrently with - * the _rcu list-mutation primitives such as hlist_add_head_rcu() - * as long as the traversal is guarded by rcu_read_lock(). - */ -#define hlist_for_each_entry_rcu(tpos, pos, head, member) \ - for (pos = (head)->first; \ - pos && ({ prefetch(pos->next); 1;}) && \ - ({ tpos = hlist_entry(pos, typeof(*tpos), member); 1;}); \ - pos = rcu_dereference(pos->next)) - -#endif /* _LINUX_LIST_H */ diff --git a/include/.svn/text-base/s3c2410.h.svn-base b/include/.svn/text-base/s3c2410.h.svn-base deleted file mode 100644 index 53d1b58..0000000 --- a/include/.svn/text-base/s3c2410.h.svn-base +++ /dev/null @@ -1,348 +0,0 @@ -/* $Id: s3c2410.h,v 1.18 2008/12/11 12:18:17 ecd Exp $ - */ - -#ifndef _X49GP_S3C2410_H -#define _X49GP_S3C2410_H 1 - -#include - -typedef struct { - const char *name; - uint32_t reset; - uint32_t *datap; -} s3c2410_offset_t; - -#define S3C2410_OFFSET(module, name, reset, data) \ - [S3C2410_ ## module ## _ ## name >> 2] = { #name, reset, &(data) } - -#define S3C2410_OFFSET_OK(p, offset) \ - ((((offset) >> 2) < (p)->nr_regs) && (p)->regs[(offset) >> 2].name) - -#define S3C2410_OFFSET_ENTRY(p, offset) &((p)->regs[(offset) >> 2]) - - -#define S3C2410_MAP_SIZE 0x00010000 - - -#define S3C2410_SRAM_BASE 0x40000000 -#define S3C2410_SRAM_SIZE 0x00001000 - -#define S3C2410_MEMC_BASE 0x48000000 - -#define S3C2410_MEMC_BWSCON 0x0000 -#define S3C2410_MEMC_BANKCON0 0x0004 -#define S3C2410_MEMC_BANKCON1 0x0008 -#define S3C2410_MEMC_BANKCON2 0x000c -#define S3C2410_MEMC_BANKCON3 0x0010 -#define S3C2410_MEMC_BANKCON4 0x0014 -#define S3C2410_MEMC_BANKCON5 0x0018 -#define S3C2410_MEMC_BANKCON6 0x001c -#define S3C2410_MEMC_BANKCON7 0x0020 -#define S3C2410_MEMC_REFRESH 0x0024 -#define S3C2410_MEMC_BANKSIZE 0x0028 -#define S3C2410_MEMC_MRSRB6 0x002c -#define S3C2410_MEMC_MRSRB7 0x0030 - -#define S3C2410_USBHOST_BASE 0x49000000 - -#define S3C2410_INTC_BASE 0x4a000000 - -#define S3C2410_INTC_SRCPND 0x0000 -#define S3C2410_INTC_INTMOD 0x0004 -#define S3C2410_INTC_INTMSK 0x0008 -#define S3C2410_INTC_PRIORITY 0x000c -#define S3C2410_INTC_INTPND 0x0010 -#define S3C2410_INTC_INTOFFSET 0x0014 -#define S3C2410_INTC_SUBSRCPND 0x0018 -#define S3C2410_INTC_INTSUBMSK 0x001c - -#define S3C2410_POWER_BASE 0x4c000000 - -#define S3C2410_POWER_LOCKTIME 0x0000 -#define S3C2410_POWER_MPLLCON 0x0004 -#define S3C2410_POWER_UPLLCON 0x0008 -#define S3C2410_POWER_CLKCON 0x000c -#define S3C2410_POWER_CLKSLOW 0x0010 -#define S3C2410_POWER_CLKDIVN 0x0014 - -#define S3C2410_LCD_BASE 0x4d000000 - -#define S3C2410_LCD_LCDCON1 0x0000 -#define S3C2410_LCD_LCDCON2 0x0004 -#define S3C2410_LCD_LCDCON3 0x0008 -#define S3C2410_LCD_LCDCON4 0x000c -#define S3C2410_LCD_LCDCON5 0x0010 -#define S3C2410_LCD_LCDSADDR1 0x0014 -#define S3C2410_LCD_LCDSADDR2 0x0018 -#define S3C2410_LCD_LCDSADDR3 0x001c -#define S3C2410_LCD_REDLUT 0x0020 -#define S3C2410_LCD_GREENLUT 0x0024 -#define S3C2410_LCD_BLUELUT 0x0028 -#define S3C2410_LCD_DITHMODE 0x004c -#define S3C2410_LCD_TPAL 0x0050 -#define S3C2410_LCD_LCDINTPND 0x0054 -#define S3C2410_LCD_LCDSRCPND 0x0058 -#define S3C2410_LCD_LCDINTMSK 0x005c -#define S3C2410_LCD_LPCSEL 0x0060 -#define S3C2410_LCD_UNKNOWN_68 0x0068 - -#define S3C2410_LCD_PALETTE_START 0x0400 -#define S3C2410_LCD_PALETTE_SIZE 0x0400 - -#define S3C2410_NAND_BASE 0x4e000000 - -#define S3C2410_NAND_NFCONF 0x0000 -#define S3C2410_NAND_NFCMD 0x0004 -#define S3C2410_NAND_NFADDR 0x0008 -#define S3C2410_NAND_NFDATA 0x000c -#define S3C2410_NAND_NFSTAT 0x0010 -#define S3C2410_NAND_NFECC 0x0014 - -#define S3C2410_UART0_BASE 0x50000000 -#define S3C2410_UART1_BASE 0x50004000 -#define S3C2410_UART2_BASE 0x50008000 - -#define S3C2410_UART0_ULCON 0x0000 -#define S3C2410_UART0_UCON 0x0004 -#define S3C2410_UART0_UFCON 0x0008 -#define S3C2410_UART0_UMCON 0x000c -#define S3C2410_UART0_UTRSTAT 0x0010 -#define S3C2410_UART0_UERSTAT 0x0014 -#define S3C2410_UART0_UFSTAT 0x0018 -#define S3C2410_UART0_UMSTAT 0x001c -#define S3C2410_UART0_UTXH 0x0020 -#define S3C2410_UART0_URXH 0x0024 -#define S3C2410_UART0_UBRDIV 0x0028 - -#define S3C2410_UART1_ULCON 0x0000 -#define S3C2410_UART1_UCON 0x0004 -#define S3C2410_UART1_UFCON 0x0008 -#define S3C2410_UART1_UMCON 0x000c -#define S3C2410_UART1_UTRSTAT 0x0010 -#define S3C2410_UART1_UERSTAT 0x0014 -#define S3C2410_UART1_UFSTAT 0x0018 -#define S3C2410_UART1_UMSTAT 0x001c -#define S3C2410_UART1_UTXH 0x0020 -#define S3C2410_UART1_URXH 0x0024 -#define S3C2410_UART1_UBRDIV 0x0028 - -#define S3C2410_UART2_ULCON 0x0000 -#define S3C2410_UART2_UCON 0x0004 -#define S3C2410_UART2_UFCON 0x0008 -#define S3C2410_UART2_UTRSTAT 0x0010 -#define S3C2410_UART2_UERSTAT 0x0014 -#define S3C2410_UART2_UFSTAT 0x0018 -#define S3C2410_UART2_UTXH 0x0020 -#define S3C2410_UART2_URXH 0x0024 -#define S3C2410_UART2_UBRDIV 0x0028 - -#define S3C2410_TIMER_BASE 0x51000000 - -#define S3C2410_TIMER_TCFG0 0x0000 -#define S3C2410_TIMER_TCFG1 0x0004 -#define S3C2410_TIMER_TCON 0x0008 -#define S3C2410_TIMER_TCNTB0 0x000c -#define S3C2410_TIMER_TCMPB0 0x0010 -#define S3C2410_TIMER_TCNTO0 0x0014 -#define S3C2410_TIMER_TCNTB1 0x0018 -#define S3C2410_TIMER_TCMPB1 0x001c -#define S3C2410_TIMER_TCNTO1 0x0020 -#define S3C2410_TIMER_TCNTB2 0x0024 -#define S3C2410_TIMER_TCMPB2 0x0028 -#define S3C2410_TIMER_TCNTO2 0x002c -#define S3C2410_TIMER_TCNTB3 0x0030 -#define S3C2410_TIMER_TCMPB3 0x0034 -#define S3C2410_TIMER_TCNTO3 0x0038 -#define S3C2410_TIMER_TCNTB4 0x003c -#define S3C2410_TIMER_TCNTO4 0x0040 - -#define S3C2410_USBDEV_BASE 0x52000000 - -#define S3C2410_USBDEV_FUNC_ADDR_REG 0x0140 -#define S3C2410_USBDEV_PWR_REG 0x0144 -#define S3C2410_USBDEV_EP_INT_REG 0x0148 -#define S3C2410_USBDEV_USB_INT_REG 0x0158 -#define S3C2410_USBDEV_EP_INT_EN_REG 0x015c -#define S3C2410_USBDEV_USB_INT_EN_REG 0x016c -#define S3C2410_USBDEV_FRAME_NUM1_REG 0x0170 -#define S3C2410_USBDEV_FRAME_NUM2_REG 0x0174 -#define S3C2410_USBDEV_INDEX_REG 0x0178 -#define S3C2410_USBDEV_EP0_FIFO_REG 0x01C0 -#define S3C2410_USBDEV_EP1_FIFO_REG 0x01C4 -#define S3C2410_USBDEV_EP2_FIFO_REG 0x01C8 -#define S3C2410_USBDEV_EP3_FIFO_REG 0x01CC -#define S3C2410_USBDEV_EP4_FIFO_REG 0x01D0 -#define S3C2410_USBDEV_EP1_DMA_CON 0x0200 -#define S3C2410_USBDEV_EP1_DMA_UNIT 0x0204 -#define S3C2410_USBDEV_EP1_DMA_FIFO 0x0208 -#define S3C2410_USBDEV_EP1_DMA_TTC_L 0x020C -#define S3C2410_USBDEV_EP1_DMA_TTC_M 0x0210 -#define S3C2410_USBDEV_EP1_DMA_TTC_H 0x0214 -#define S3C2410_USBDEV_EP2_DMA_CON 0x0218 -#define S3C2410_USBDEV_EP2_DMA_UNIT 0x021C -#define S3C2410_USBDEV_EP2_DMA_FIFO 0x0220 -#define S3C2410_USBDEV_EP2_DMA_TTC_L 0x0224 -#define S3C2410_USBDEV_EP2_DMA_TTC_M 0x0228 -#define S3C2410_USBDEV_EP2_DMA_TTC_H 0x022C -#define S3C2410_USBDEV_EP3_DMA_CON 0x0240 -#define S3C2410_USBDEV_EP3_DMA_UNIT 0x0244 -#define S3C2410_USBDEV_EP3_DMA_FIFO 0x0248 -#define S3C2410_USBDEV_EP3_DMA_TTC_L 0x024C -#define S3C2410_USBDEV_EP3_DMA_TTC_M 0x0250 -#define S3C2410_USBDEV_EP3_DMA_TTC_H 0x0254 -#define S3C2410_USBDEV_EP4_DMA_CON 0x0258 -#define S3C2410_USBDEV_EP4_DMA_UNIT 0x025C -#define S3C2410_USBDEV_EP4_DMA_FIFO 0x0260 -#define S3C2410_USBDEV_EP4_DMA_TTC_L 0x0264 -#define S3C2410_USBDEV_EP4_DMA_TTC_M 0x0268 -#define S3C2410_USBDEV_EP4_DMA_TTC_H 0x026C -#define S3C2410_USBDEV_MAXP_REG_WRONG 0x0180 -#define S3C2410_USBDEV_IN_CSR1_REG_EP0_CSR 0x0184 -#define S3C2410_USBDEV_IN_CSR2_REG 0x0188 -#define S3C2410_USBDEV_MAXP_REG 0x018c -#define S3C2410_USBDEV_OUT_CSR1_REG 0x0190 -#define S3C2410_USBDEV_OUT_CSR2_REG 0x0194 -#define S3C2410_USBDEV_OUT_FIFO_CNT1_REG 0x0198 -#define S3C2410_USBDEV_OUT_FIFO_CNT2_REG 0x019C - -#define S3C2410_WATCHDOG_BASE 0x53000000 - -#define S3C2410_WATCHDOG_WTCON 0x0000 -#define S3C2410_WATCHDOG_WTDAT 0x0004 -#define S3C2410_WATCHDOG_WTCNT 0x0008 - -#define S3C2410_IO_PORT_BASE 0x56000000 - -#define S3C2410_IO_PORT_GPACON 0x0000 -#define S3C2410_IO_PORT_GPADAT 0x0004 -#define S3C2410_IO_PORT_GPBCON 0x0010 -#define S3C2410_IO_PORT_GPBDAT 0x0014 -#define S3C2410_IO_PORT_GPBUP 0x0018 -#define S3C2410_IO_PORT_GPCCON 0x0020 -#define S3C2410_IO_PORT_GPCDAT 0x0024 -#define S3C2410_IO_PORT_GPCUP 0x0028 -#define S3C2410_IO_PORT_GPDCON 0x0030 -#define S3C2410_IO_PORT_GPDDAT 0x0034 -#define S3C2410_IO_PORT_GPDUP 0x0038 -#define S3C2410_IO_PORT_GPECON 0x0040 -#define S3C2410_IO_PORT_GPEDAT 0x0044 -#define S3C2410_IO_PORT_GPEUP 0x0048 -#define S3C2410_IO_PORT_GPFCON 0x0050 -#define S3C2410_IO_PORT_GPFDAT 0x0054 -#define S3C2410_IO_PORT_GPFUP 0x0058 -#define S3C2410_IO_PORT_GPGCON 0x0060 -#define S3C2410_IO_PORT_GPGDAT 0x0064 -#define S3C2410_IO_PORT_GPGUP 0x0068 -#define S3C2410_IO_PORT_GPHCON 0x0070 -#define S3C2410_IO_PORT_GPHDAT 0x0074 -#define S3C2410_IO_PORT_GPHUP 0x0078 -#define S3C2410_IO_PORT_MISCCR 0x0080 -#define S3C2410_IO_PORT_DCLKCON 0x0084 -#define S3C2410_IO_PORT_EXTINT0 0x0088 -#define S3C2410_IO_PORT_EXTINT1 0x008c -#define S3C2410_IO_PORT_EXTINT2 0x0090 -#define S3C2410_IO_PORT_EINTFLT0 0x0094 -#define S3C2410_IO_PORT_EINTFLT1 0x0098 -#define S3C2410_IO_PORT_EINTFLT2 0x009c -#define S3C2410_IO_PORT_EINTFLT3 0x00a0 -#define S3C2410_IO_PORT_EINTMASK 0x00a4 -#define S3C2410_IO_PORT_EINTPEND 0x00a8 -#define S3C2410_IO_PORT_GSTATUS0 0x00ac -#define S3C2410_IO_PORT_GSTATUS1 0x00b0 -#define S3C2410_IO_PORT_GSTATUS2 0x00b4 -#define S3C2410_IO_PORT_GSTATUS3 0x00b8 -#define S3C2410_IO_PORT_GSTATUS4 0x00bc - -#define S3C2410_RTC_BASE 0x57000000 - -#define S3C2410_RTC_RTCCON 0x0040 -#define S3C2410_RTC_TICNT 0x0044 -#define S3C2410_RTC_RTCALM 0x0050 -#define S3C2410_RTC_ALMSEC 0x0054 -#define S3C2410_RTC_ALMMIN 0x0058 -#define S3C2410_RTC_ALMHOUR 0x005c -#define S3C2410_RTC_ALMDATE 0x0060 -#define S3C2410_RTC_ALMMON 0x0064 -#define S3C2410_RTC_ALMYEAR 0x0068 -#define S3C2410_RTC_RTCRST 0x006c -#define S3C2410_RTC_BCDSEC 0x0070 -#define S3C2410_RTC_BCDMIN 0x0074 -#define S3C2410_RTC_BCDHOUR 0x0078 -#define S3C2410_RTC_BCDDATE 0x007c -#define S3C2410_RTC_BCDDAY 0x0080 -#define S3C2410_RTC_BCDMON 0x0084 -#define S3C2410_RTC_BCDYEAR 0x0088 - -#define S3C2410_ADC_BASE 0x58000000 - -#define S3C2410_ADC_ADCCON 0x0000 -#define S3C2410_ADC_ADCTSC 0x0004 -#define S3C2410_ADC_ADCDLY 0x0008 -#define S3C2410_ADC_ADCDAT0 0x000c -#define S3C2410_ADC_ADCDAT1 0x0010 - -#define S3C2410_SPI_BASE 0x59000000 - -#define S3C2410_SPI_SPICON0 0x0000 -#define S3C2410_SPI_SPISTA0 0x0004 -#define S3C2410_SPI_SPPIN0 0x0008 -#define S3C2410_SPI_SPPRE0 0x000c -#define S3C2410_SPI_SPTDAT0 0x0010 -#define S3C2410_SPI_SPRDAT0 0x0014 -#define S3C2410_SPI_SPICON1 0x0020 -#define S3C2410_SPI_SPISTA1 0x0024 -#define S3C2410_SPI_SPPIN1 0x0028 -#define S3C2410_SPI_SPPRE1 0x002c -#define S3C2410_SPI_SPTDAT1 0x0030 -#define S3C2410_SPI_SPRDAT1 0x0034 - -#define S3C2410_SDI_BASE 0x5a000000 - -#define S3C2410_SDI_SDICON 0x0000 -#define S3C2410_SDI_SDIPRE 0x0004 -#define S3C2410_SDI_SDICARG 0x0008 -#define S3C2410_SDI_SDICCON 0x000c -#define S3C2410_SDI_SDICSTA 0x0010 -#define S3C2410_SDI_SDIRSP0 0x0014 -#define S3C2410_SDI_SDIRSP1 0x0018 -#define S3C2410_SDI_SDIRSP2 0x001c -#define S3C2410_SDI_SDIRSP3 0x0020 -#define S3C2410_SDI_SDIDTIMER 0x0024 -#define S3C2410_SDI_SDIBSIZE 0x0028 -#define S3C2410_SDI_SDIDCON 0x002c -#define S3C2410_SDI_SDIDCNT 0x0030 -#define S3C2410_SDI_SDIDSTA 0x0034 -#define S3C2410_SDI_SDIFSTA 0x0038 -#define S3C2410_SDI_SDIDAT 0x003c -#define S3C2410_SDI_SDIIMSK 0x0040 - - -extern int x49gp_s3c2410_init(x49gp_t *x49gp); -extern int x49gp_s3c2410_arm_init(x49gp_t *x49gp); -extern int x49gp_s3c2410_mmu_init(x49gp_t *x49gp); -extern int x49gp_s3c2410_sram_init(x49gp_t *x49gp); -extern int x49gp_s3c2410_memc_init(x49gp_t *x49gp); -extern int x49gp_s3c2410_intc_init(x49gp_t *x49gp); -extern int x49gp_s3c2410_power_init(x49gp_t *x49gp); -extern int x49gp_s3c2410_lcd_init(x49gp_t *x49gp); -extern int x49gp_s3c2410_nand_init(x49gp_t *x49gp); -extern int x49gp_s3c2410_uart_init(x49gp_t *x49gp); -extern int x49gp_s3c2410_timer_init(x49gp_t *x49gp); -extern int x49gp_s3c2410_usbdev_init(x49gp_t *x49gp); -extern int x49gp_s3c2410_watchdog_init(x49gp_t *x49gp); -extern int x49gp_s3c2410_io_port_init(x49gp_t *x49gp); -extern int x49gp_s3c2410_rtc_init(x49gp_t *x49gp); -extern int x49gp_s3c2410_adc_init(x49gp_t *x49gp); -extern int x49gp_s3c2410_spi_init(x49gp_t *x49gp); -extern int x49gp_s3c2410_sdi_init(x49gp_t *x49gp); - -extern void s3c2410_io_port_g_set_bit(x49gp_t *x49gp, int n, uint32_t set); -extern void s3c2410_io_port_f_set_bit(x49gp_t *x49gp, int n, uint32_t set); - -extern void x49gp_schedule_lcd_update(x49gp_t *x49gp); -extern void x49gp_lcd_update(x49gp_t *x49gp); - -extern unsigned long s3c2410_timer_next_interrupt(x49gp_t *x49gp); -extern unsigned long s3c2410_watchdog_next_interrupt(x49gp_t *x49gp); - -#endif /* !(_X49GP_S3C2410_H) */ diff --git a/include/.svn/text-base/s3c2410_intc.h.svn-base b/include/.svn/text-base/s3c2410_intc.h.svn-base deleted file mode 100644 index b3c5ffd..0000000 --- a/include/.svn/text-base/s3c2410_intc.h.svn-base +++ /dev/null @@ -1,72 +0,0 @@ -/* $Id: s3c2410_intc.h,v 1.3 2008/12/11 12:18:17 ecd Exp $ - */ - -#ifndef _X49GP_S3C2410_INTC_H -#define _X49GP_S3C2410_INTC_H 1 - -#define INT_ADC 31 -#define INT_RTC 30 -#define INT_SPI1 29 -#define INT_UART0 28 -#define INT_IIC 27 -#define INT_USBH 26 -#define INT_USBD 25 -#define INT_UART1 23 -#define INT_SPI0 22 -#define INT_SDI 21 -#define INT_DMA3 20 -#define INT_DMA2 19 -#define INT_DMA1 18 -#define INT_DMA0 17 -#define INT_LCD 16 -#define INT_UART2 15 -#define INT_TIMER4 14 -#define INT_TIMER3 13 -#define INT_TIMER2 12 -#define INT_TIMER1 11 -#define INT_TIMER0 10 -#define INT_WDT 9 -#define INT_TICK 8 -#define nBATT_FLT 7 -#define EINT8_23 5 -#define EINT4_7 4 -#define EINT3 3 -#define EINT2 2 -#define EINT1 1 -#define EINT0 0 - -#define SUB_INT_ADC 10 -#define SUB_INT_TC 9 -#define SUB_INT_ERR2 8 -#define SUB_INT_TXD2 7 -#define SUB_INT_RXD2 6 -#define SUB_INT_ERR1 5 -#define SUB_INT_TXD1 4 -#define SUB_INT_RXD1 3 -#define SUB_INT_ERR0 2 -#define SUB_INT_TXD0 1 -#define SUB_INT_RXD0 0 - -#define ARB0_MODE (1 << 0) -#define ARB1_MODE (1 << 1) -#define ARB2_MODE (1 << 2) -#define ARB3_MODE (1 << 3) -#define ARB4_MODE (1 << 4) -#define ARB5_MODE (1 << 5) -#define ARB6_MODE (1 << 6) -#define ARB0_SEL_SHIFT 7 -#define ARB1_SEL_SHIFT 9 -#define ARB2_SEL_SHIFT 11 -#define ARB3_SEL_SHIFT 13 -#define ARB4_SEL_SHIFT 15 -#define ARB5_SEL_SHIFT 17 -#define ARB6_SEL_SHIFT 19 -#define ARBx_SEL_MASK 3 - -void s3c2410_intc_sub_assert(x49gp_t *x49gp, int sub_irq, int level); -void s3c2410_intc_sub_deassert(x49gp_t *x49gp, int sub_irq); - -void s3c2410_intc_assert(x49gp_t *x49gp, int irq, int level); -void s3c2410_intc_deassert(x49gp_t *x49gp, int irq); - -#endif /* !(_X49GP_S3C2410_INTC_H) */ diff --git a/include/.svn/text-base/s3c2410_mmu.h.svn-base b/include/.svn/text-base/s3c2410_mmu.h.svn-base deleted file mode 100644 index 561e2da..0000000 --- a/include/.svn/text-base/s3c2410_mmu.h.svn-base +++ /dev/null @@ -1,37 +0,0 @@ -/* $Id: s3c2410_mmu.h,v 1.3 2008/12/11 12:18:17 ecd Exp $ - */ - -#ifndef _S3C2410_MMU_H -#define _S3C2410_MMU_H 1 - -#define S3C2410_MMU_TLB_SIZE 64 -#define S3C2410_MMU_TLB_MASK (S3C2410_MMU_TLB_SIZE - 1) - -typedef struct { - uint32_t mva; - uint32_t mask; - uint32_t pa; - uint32_t dac; - int valid; -} TLB_entry_t; - -typedef struct { - int victim; - int base; - int index0; - int index1; - unsigned long hit0; - unsigned long hit1; - unsigned long search; - unsigned long nsearch; - unsigned long walk; - TLB_entry_t data[S3C2410_MMU_TLB_SIZE]; -} TLB_t; - -typedef struct { - uint32_t MMUReg[16]; - TLB_t iTLB; - TLB_t dTLB; -} s3c2410_mmu_t; - -#endif /* !(_S3C2410_MMU_H) */ diff --git a/include/.svn/text-base/s3c2410_power.h.svn-base b/include/.svn/text-base/s3c2410_power.h.svn-base deleted file mode 100644 index 88c3a57..0000000 --- a/include/.svn/text-base/s3c2410_power.h.svn-base +++ /dev/null @@ -1,28 +0,0 @@ -/* $Id: s3c2410_power.h,v 1.3 2008/12/11 12:18:17 ecd Exp $ - */ - -#ifndef _S3C2410_POWER_H -#define _S3C2410_POWER_H 1 - -#define CLKCON_SPI 0x00040000 -#define CLKCON_IIS 0x00020000 -#define CLKCON_IIC 0x00010000 -#define CLKCON_ADC 0x00008000 -#define CLKCON_RTC 0x00004000 -#define CLKCON_GPIO 0x00002000 -#define CLKCON_UART2 0x00001000 -#define CLKCON_UART1 0x00000800 -#define CLKCON_UART0 0x00000400 -#define CLKCON_SDI 0x00000200 -#define CLKCON_TIMER 0x00000100 -#define CLKCON_USBD 0x00000080 -#define CLKCON_USBH 0x00000040 -#define CLKCON_LCD 0x00000020 -#define CLKCON_NAND 0x00000010 -#define CLKCON_POWER_OFF 0x00000008 -#define CLKCON_IDLE 0x00000004 -#define CLKCON_SM_BIT 0x00000001 - -extern int s3c2410_idle; - -#endif /* !(_S3C2410_POWER_H) */ diff --git a/include/.svn/text-base/s3c2410_timer.h.svn-base b/include/.svn/text-base/s3c2410_timer.h.svn-base deleted file mode 100644 index 5fcfe25..0000000 --- a/include/.svn/text-base/s3c2410_timer.h.svn-base +++ /dev/null @@ -1,48 +0,0 @@ -/* $Id: s3c2410_timer.h,v 1.3 2008/12/11 12:18:17 ecd Exp $ - */ - -#ifndef _S3C2410_TIMER_H -#define _S3C2410_TIMER_H 1 - -#include - -#define TCFG0_DEAD_SHIFT 16 -#define TCFG0_DEAD_MASK 0xff -#define TCFG0_PRE1_SHIFT 8 -#define TCFG0_PRE0_SHIFT 0 -#define TCFG0_PREx_MASK 0xff - -#define TCFG1_DMA_SHIFT 20 -#define TCFG1_DMA_MASK 0x0f -#define TCFG1_MUX4_SHIFT 16 -#define TCFG1_MUX3_SHIFT 12 -#define TCFG1_MUX2_SHIFT 8 -#define TCFG1_MUX1_SHIFT 4 -#define TCFG1_MUX0_SHIFT 0 -#define TCFG1_MUXx_MASK 0x0f - -#define TCON_TIMER4_RELOAD 0x00400000 -#define TCON_TIMER4_UPDATE 0x00200000 -#define TCON_TIMER4_START 0x00100000 -#define TCON_TIMER3_RELOAD 0x00080000 -#define TCON_TIMER3_INVERT 0x00040000 -#define TCON_TIMER3_UPDATE 0x00020000 -#define TCON_TIMER3_START 0x00010000 -#define TCON_TIMER2_RELOAD 0x00008000 -#define TCON_TIMER2_INVERT 0x00004000 -#define TCON_TIMER2_UPDATE 0x00002000 -#define TCON_TIMER2_START 0x00001000 -#define TCON_TIMER1_RELOAD 0x00000800 -#define TCON_TIMER1_INVERT 0x00000400 -#define TCON_TIMER1_UPDATE 0x00000200 -#define TCON_TIMER1_START 0x00000100 -#define TCON_TIMER0_DEADZONE 0x00000010 -#define TCON_TIMER0_RELOAD 0x00000008 -#define TCON_TIMER0_INVERT 0x00000004 -#define TCON_TIMER0_UPDATE 0x00000002 -#define TCON_TIMER0_START 0x00000001 - -void s3c2410_run_timers(x49gp_t *x49gp); -clock_t s3c2410_next_timer(x49gp_t *x49gp); - -#endif /* !(_S3C2410_TIMER_H) */ diff --git a/include/.svn/text-base/saturn.h.svn-base b/include/.svn/text-base/saturn.h.svn-base deleted file mode 100644 index b1102ff..0000000 --- a/include/.svn/text-base/saturn.h.svn-base +++ /dev/null @@ -1,43 +0,0 @@ -/* $Id: saturn.h,v 1.1 2008/12/11 12:18:17 ecd Exp $ - */ - -#ifndef SATURN_H -#define SATURN_H 1 - -#define NB_RSTK 8 - -typedef uint64_t saturn_reg_t; - -typedef struct { - uint32_t read_map[256 + 1]; - uint32_t write_map[256 + 1]; - uint8_t top_map[256 + 1 + 3]; - saturn_reg_t A; - saturn_reg_t B; - saturn_reg_t C; - saturn_reg_t D; - saturn_reg_t R0; - saturn_reg_t R1; - saturn_reg_t R2; - saturn_reg_t R3; - saturn_reg_t R4; - uint32_t D0; - uint32_t D1; - uint32_t P, P4, P4_32; - uint32_t ST; - uint32_t HST; - uint32_t carry; - int dec; - uint32_t RSTK[NB_RSTK]; - uint32_t RSTK_i; - uint32_t REG_FIELD[32]; - uint32_t FIELD_START[32]; - uint32_t FIELD_LENGTH[32]; -} saturn_cpu_t; - -#define SAT_RPLTOP 0x8076b -#define SAT_RSKTOP 0x806f3 /* RETTOP */ -#define SAT_DSKTOP 0x806f8 -#define SAT_EDITLINE 0x806fd - -#endif /* !(SATURN_H) */ diff --git a/include/.svn/text-base/symbol.h.svn-base b/include/.svn/text-base/symbol.h.svn-base deleted file mode 100644 index 53174f6..0000000 --- a/include/.svn/text-base/symbol.h.svn-base +++ /dev/null @@ -1,68 +0,0 @@ -/* $Id: symbol.h,v 1.4 2008/12/11 12:18:17 ecd Exp $ - */ - -#ifndef _X49GP_SYMBOL_H -#define _X49GP_SYMBOL_H 1 - -#include - -typedef struct { - const cairo_path_data_t *data; - int num_data; -} symbol_path_t; - -typedef struct { - double x_advance; - double y_advance; - double llx; - double lly; - double urx; - double ury; - double prescale; - double postscale; - const symbol_path_t *path; -} x49gp_symbol_t; - -#define SYMBOL_MOVE_TO(x, y) \ - { header: { CAIRO_PATH_MOVE_TO, 2 } }, \ - { point: { x, y } } - -#define SYMBOL_LINE_TO(x, y) \ - { header: { CAIRO_PATH_LINE_TO, 2 } }, \ - { point: { x, y } } - -#define SYMBOL_CURVE_TO(x1, y1, x2, y2, x3, y3) \ - { header: { CAIRO_PATH_CURVE_TO, 4 } }, \ - { point: { x1, y1 } }, \ - { point: { x2, y2 } }, \ - { point: { x3, y3 } } - -#define SYMBOL_CLOSE_PATH() \ - { header: { CAIRO_PATH_CLOSE_PATH, 1 } } - -#define SYMBOL(name, x_advance, y_advance, llx, lly, urx, ury) \ -static const symbol_path_t symbol_##name##_path = \ -{ \ - symbol_##name##_path_data, \ - sizeof(symbol_##name##_path_data) / sizeof(cairo_path_data_t) \ -}; \ - \ -static const x49gp_symbol_t symbol_##name = \ -{ \ - x_advance, y_advance, llx, lly, urx, ury, 1.0, 1.0, \ - &symbol_##name##_path \ -} - -#define CONTROL(name, x_advance, y_advance, prescale, postscale) \ -static const x49gp_symbol_t symbol_##name = \ -{ \ - x_advance, y_advance, 0.0, 0.0, 0.0, 0.0, \ - prescale, postscale, NULL \ -} - -int symbol_lookup_glyph_by_name(const char *name, int namelen, gunichar *); - -const x49gp_symbol_t *symbol_get_by_name(const char *name); -const x49gp_symbol_t *symbol_get_by_glyph(gunichar glyph); - -#endif /* !(_X49GP_SYMBOL_H) */ diff --git a/include/.svn/text-base/x49gp.h.svn-base b/include/.svn/text-base/x49gp.h.svn-base deleted file mode 100644 index 6739281..0000000 --- a/include/.svn/text-base/x49gp.h.svn-base +++ /dev/null @@ -1,144 +0,0 @@ -/* $Id: x49gp.h,v 1.15 2008/12/11 12:18:17 ecd Exp $ - */ - -#ifndef _X49GP_H -#define _X49GP_H - -#include -#include -#include - -#include - -#include - -#include -#include -#include -#include -#include - -/* LD TEMPO HACK */ -#ifndef QEMU_OLD -extern uint8_t *phys_ram_base; -extern int phys_ram_size; -#endif - -typedef enum { - X49GP_ARM_RUN = 0, - X49GP_ARM_SLEEP, - X49GP_ARM_OFF -} x49gp_arm_idle_t; - -typedef enum { - X49GP_RESET_POWER_ON = 0, - X49GP_RESET_POWER_OFF, - X49GP_RESET_WATCHDOG -} x49gp_reset_t; - -struct __x49gp_module_s__; -typedef struct __x49gp_module_s__ x49gp_module_t; - -struct __x49gp_module_s__ { - const char *name; - - int (*init) (x49gp_module_t *); - int (*exit) (x49gp_module_t *); - - int (*reset) (x49gp_module_t *, x49gp_reset_t); - - int (*load) (x49gp_module_t *, GKeyFile *); - int (*save) (x49gp_module_t *, GKeyFile *); - - void *user_data; - - x49gp_t *x49gp; - struct list_head list; -}; - - -struct __x49gp_s__ { - CPUARMState *env; - - struct list_head modules; - - void *s3c2410_lcd; - void *s3c2410_timer; - void *s3c2410_watchdog; - void *s3c2410_intc; - void *s3c2410_io_port; - - void *timer; - uint8_t *sram; - - uint32_t MCLK; - uint32_t UCLK; - - uint32_t FCLK; - uint32_t HCLK; - uint32_t PCLK; - int PCLK_ratio; - - clock_t clk_tck; - unsigned long emulator_fclk; - - unsigned char keybycol[8]; - unsigned char keybyrow[8]; - - x49gp_timer_t *gtk_timer; - x49gp_timer_t *lcd_timer; - - x49gp_arm_idle_t arm_idle; - int arm_exit; - - x49gp_ui_t *ui; - - GKeyFile *config; - const char *progname; -}; - -extern void x49gp_set_idle(x49gp_t *, x49gp_arm_idle_t idle); - -extern int x49gp_module_init(x49gp_t *x49gp, const char *name, - int (*init)(x49gp_module_t *), - int (*exit)(x49gp_module_t *), - int (*reset)(x49gp_module_t *, x49gp_reset_t), - int (*load)(x49gp_module_t *, GKeyFile *), - int (*save)(x49gp_module_t *, GKeyFile *), - void *user_data, x49gp_module_t **module); - -extern int x49gp_module_register(x49gp_module_t *module); -extern int x49gp_module_unregister(x49gp_module_t *module); - -extern char *x49gp_module_get_filename(x49gp_module_t *module, GKeyFile *, - const char *key); -extern int x49gp_module_get_int(x49gp_module_t *module, GKeyFile *, - const char *, int, int *); -extern int x49gp_module_set_int(x49gp_module_t *module, GKeyFile *, - const char *, int); -extern int x49gp_module_get_uint(x49gp_module_t *module, GKeyFile *, - const char *, - unsigned int, unsigned int *); -extern int x49gp_module_set_uint(x49gp_module_t *module, GKeyFile *, - const char *, unsigned int); -extern int x49gp_module_get_u32(x49gp_module_t *module, GKeyFile *, - const char *, uint32_t, uint32_t *); -extern int x49gp_module_set_u32(x49gp_module_t *module, GKeyFile *, - const char *, uint32_t); -extern int x49gp_module_get_u64(x49gp_module_t *module, GKeyFile *, - const char *, uint64_t, uint64_t *); -extern int x49gp_module_set_u64(x49gp_module_t *module, GKeyFile *, - const char *, uint64_t); -extern int x49gp_module_get_string(x49gp_module_t *module, GKeyFile *, - const char *, char *, char **); - -extern int x49gp_modules_init(x49gp_t *); -extern int x49gp_modules_exit(x49gp_t *); -extern int x49gp_modules_reset(x49gp_t *, x49gp_reset_t); -extern int x49gp_modules_load(x49gp_t *, const char *); -extern int x49gp_modules_save(x49gp_t *, const char *); - -extern int x49gp_flash_init(x49gp_t *); -extern int x49gp_sram_init(x49gp_t *); - -#endif /* !(_X49GP_H) */ diff --git a/include/.svn/text-base/x49gp_timer.h.svn-base b/include/.svn/text-base/x49gp_timer.h.svn-base deleted file mode 100644 index e5acdcb..0000000 --- a/include/.svn/text-base/x49gp_timer.h.svn-base +++ /dev/null @@ -1,32 +0,0 @@ -/* $Id: x49gp_timer.h,v 1.3 2008/12/11 12:18:17 ecd Exp $ - */ - -#ifndef _X49GP_TIMER_H -#define _X49GP_TIMER_H 1 - -#include -#include - -#define X49GP_TIMER_VIRTUAL 0 -#define X49GP_TIMER_REALTIME 1 - -int64_t x49gp_get_clock(void); - -typedef void (*x49gp_timer_cb_t) (void *); -typedef struct x49gp_timer_s x49gp_timer_t; - -x49gp_timer_t *x49gp_new_timer(long type, x49gp_timer_cb_t, void *user_data); -void x49gp_free_timer(x49gp_timer_t *); - -void x49gp_mod_timer(x49gp_timer_t *, int64_t expires); -void x49gp_del_timer(x49gp_timer_t *); -int x49gp_timer_pending(x49gp_timer_t *); -int64_t x49gp_timer_expires(x49gp_timer_t *); - -#define X49GP_GTK_REFRESH_INTERVAL 30000LL -#define X49GP_LCD_REFRESH_INTERVAL 50000LL - -int x49gp_main_loop(x49gp_t *); -int x49gp_timer_init(x49gp_t *); - -#endif /* !(_X49GP_TIMER_H) */ diff --git a/include/.svn/text-base/x49gp_types.h.svn-base b/include/.svn/text-base/x49gp_types.h.svn-base deleted file mode 100644 index f6b52d7..0000000 --- a/include/.svn/text-base/x49gp_types.h.svn-base +++ /dev/null @@ -1,23 +0,0 @@ -/* $Id: x49gp_types.h,v 1.5 2008/12/11 12:18:17 ecd Exp $ - */ - -#ifndef _X49GP_TYPES_H -#define _X49GP_TYPES_H 1 - -typedef signed char s8; -typedef signed short s16; -typedef signed int s32; -typedef signed long long s64; - -typedef unsigned char u8; -typedef unsigned short u16; -typedef unsigned int u32; -typedef unsigned long long u64; - -struct __x49gp_s__; -typedef struct __x49gp_s__ x49gp_t; - -struct __x49gp_ui_s__; -typedef struct __x49gp_ui_s__ x49gp_ui_t; - -#endif /* !(_X49GP_TYPES_H) */ diff --git a/include/.svn/text-base/x49gp_ui.h.svn-base b/include/.svn/text-base/x49gp_ui.h.svn-base deleted file mode 100644 index e019b78..0000000 --- a/include/.svn/text-base/x49gp_ui.h.svn-base +++ /dev/null @@ -1,125 +0,0 @@ -/* $Id: x49gp_ui.h,v 1.14 2008/12/11 12:18:17 ecd Exp $ - */ - -#ifndef _X49GP_UI_H -#define _X49GP_UI_H 1 - -#include - -typedef enum { - UI_COLOR_BLACK = 0, - UI_COLOR_WHITE, - UI_COLOR_YELLOW, - UI_COLOR_RED, - UI_COLOR_GREEN, - UI_COLOR_SILVER, - UI_COLOR_ORANGE, - UI_COLOR_BLUE, - UI_COLOR_MAX -} x49gp_ui_color_t; - -typedef enum { - UI_SHAPE_BUTTON_TINY = 0, - UI_SHAPE_BUTTON_SMALL, - UI_SHAPE_BUTTON_NORMAL, - UI_SHAPE_BUTTON_LARGE, - UI_SHAPE_BUTTON_ROUND, - UI_SHAPE_MAX -} x49gp_ui_shape_t; - -typedef enum { - UI_LAYOUT_LEFT = 0, - UI_LAYOUT_LEFT_NO_SPACE, - UI_LAYOUT_BELOW, - UI_LAYOUT_MAX -} x49gp_ui_layout_t; - -typedef enum { - UI_CALCULATOR_HP49GP = 0, - UI_CALCULATOR_HP50G -} x49gp_ui_calculator_t; - - -typedef struct { - const char *label; - const char *letter; - const char *left; - const char *right; - const char *below; - x49gp_ui_color_t color; - double font_size; - cairo_font_weight_t font_weight; - x49gp_ui_shape_t shape; - double letter_size; - x49gp_ui_layout_t layout; - int x; - int y; - int width; - int height; - int column; - int row; - unsigned char columnbit; - unsigned char rowbit; - int eint; -} x49gp_ui_key_t; - -typedef struct { - x49gp_t *x49gp; - const x49gp_ui_key_t *key; - GtkWidget *button; - GtkWidget *label; - GtkWidget *box; - GdkPixmap *pixmap; - gboolean down; - gboolean hold; -} x49gp_ui_button_t; - -struct __x49gp_ui_s__ { - GtkWidget *window; - GtkWidget *fixed; - - GdkPixbuf *bg_pixbuf; - GdkPixmap *bg_pixmap; - GtkWidget *background; - - GdkColor colors[UI_COLOR_MAX]; - GdkBitmap *shapes[UI_SHAPE_MAX]; - - x49gp_ui_calculator_t calculator; - - x49gp_ui_button_t *buttons; - unsigned int nr_buttons; - - GtkWidget *lcd_canvas; - GdkPixmap *lcd_pixmap; - - GdkGC *ann_left_gc; - GdkGC *ann_right_gc; - GdkGC *ann_alpha_gc; - GdkGC *ann_battery_gc; - GdkGC *ann_busy_gc; - GdkGC *ann_io_gc; - - GdkBitmap *ann_left; - GdkBitmap *ann_right; - GdkBitmap *ann_alpha; - GdkBitmap *ann_battery; - GdkBitmap *ann_busy; - GdkBitmap *ann_io; - - gint width; - gint height; - - gint kb_x_offset; - gint kb_y_offset; - - gint lcd_x_offset; - gint lcd_y_offset; - gint lcd_width; - gint lcd_height; - gint lcd_top_margin; -}; - -int x49gp_ui_init(x49gp_t *x49gp); - -#endif /* !(_X49GP_UI_H) */ diff --git a/include/CVS/.svn/all-wcprops b/include/CVS/.svn/all-wcprops deleted file mode 100644 index 71d6180..0000000 --- a/include/CVS/.svn/all-wcprops +++ /dev/null @@ -1,23 +0,0 @@ -K 25 -svn:wc:ra_dav:version-url -V 36 -/p/x49gp/code/!svn/ver/1/include/CVS -END -Repository -K 25 -svn:wc:ra_dav:version-url -V 47 -/p/x49gp/code/!svn/ver/1/include/CVS/Repository -END -Root -K 25 -svn:wc:ra_dav:version-url -V 41 -/p/x49gp/code/!svn/ver/1/include/CVS/Root -END -Entries -K 25 -svn:wc:ra_dav:version-url -V 44 -/p/x49gp/code/!svn/ver/1/include/CVS/Entries -END diff --git a/include/CVS/.svn/entries b/include/CVS/.svn/entries deleted file mode 100644 index 613a7a3..0000000 --- a/include/CVS/.svn/entries +++ /dev/null @@ -1,130 +0,0 @@ -10 - -dir -11 -http://svn.code.sf.net/p/x49gp/code/include/CVS -http://svn.code.sf.net/p/x49gp/code - - - -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - -481df3bd-3408-496c-b7de-451e46197bb5 - -Repository -file - - - - -2013-08-23T00:54:46.000000Z -787f1f54d99013d8c01d85d015aa21ed -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -14 - -Root -file - - - - -2013-08-23T00:54:46.000000Z -f51b768066a9e7d88829b19678326fcd -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -60 - -Entries -file - - - - -2013-08-23T00:54:46.000000Z -078400b504794b71bc803fc0f7dd0736 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -748 - diff --git a/include/CVS/.svn/text-base/Entries.svn-base b/include/CVS/.svn/text-base/Entries.svn-base deleted file mode 100644 index 9e08e9f..0000000 --- a/include/CVS/.svn/text-base/Entries.svn-base +++ /dev/null @@ -1,18 +0,0 @@ -/bitmap_font.h/1.5/Thu Dec 11 12:18:17 2008// -/bitmaps.h/1.9/Thu Dec 11 12:18:17 2008// -/block.h/1.1/Thu Dec 11 12:18:17 2008// -/byteorder.h/1.5/Thu Dec 11 12:18:17 2008// -/glyphname.h/1.3/Thu Dec 11 12:18:17 2008// -/list.h/1.5/Thu Dec 11 12:18:17 2008// -/s3c2410.h/1.18/Thu Dec 11 12:18:17 2008// -/s3c2410_intc.h/1.3/Thu Dec 11 12:18:17 2008// -/s3c2410_mmu.h/1.3/Thu Dec 11 12:18:17 2008// -/s3c2410_power.h/1.3/Thu Dec 11 12:18:17 2008// -/s3c2410_timer.h/1.3/Thu Dec 11 12:18:17 2008// -/saturn.h/1.1/Thu Dec 11 12:18:17 2008// -/symbol.h/1.4/Thu Dec 11 12:18:17 2008// -/x49gp.h/1.15/Thu Dec 11 12:18:17 2008// -/x49gp_timer.h/1.3/Thu Dec 11 12:18:17 2008// -/x49gp_types.h/1.5/Thu Dec 11 12:18:17 2008// -/x49gp_ui.h/1.14/Thu Dec 11 12:18:17 2008// -D diff --git a/include/CVS/.svn/text-base/Repository.svn-base b/include/CVS/.svn/text-base/Repository.svn-base deleted file mode 100644 index 9500df1..0000000 --- a/include/CVS/.svn/text-base/Repository.svn-base +++ /dev/null @@ -1 +0,0 @@ -x49gp/include diff --git a/include/CVS/.svn/text-base/Root.svn-base b/include/CVS/.svn/text-base/Root.svn-base deleted file mode 100644 index 6f29e94..0000000 --- a/include/CVS/.svn/text-base/Root.svn-base +++ /dev/null @@ -1 +0,0 @@ -:pserver:anonymous@x49gp.cvs.sourceforge.net:/cvsroot/x49gp diff --git a/qemu/.svn/all-wcprops b/qemu/.svn/all-wcprops deleted file mode 100644 index 7e316fe..0000000 --- a/qemu/.svn/all-wcprops +++ /dev/null @@ -1,23 +0,0 @@ -K 25 -svn:wc:ra_dav:version-url -V 30 -/p/x49gp/code/!svn/ver/10/qemu -END -prepare.sh -K 25 -svn:wc:ra_dav:version-url -V 40 -/p/x49gp/code/!svn/ver/1/qemu/prepare.sh -END -.cvsignore -K 25 -svn:wc:ra_dav:version-url -V 40 -/p/x49gp/code/!svn/ver/1/qemu/.cvsignore -END -qemu-0.9.0.tar.gz -K 25 -svn:wc:ra_dav:version-url -V 47 -/p/x49gp/code/!svn/ver/1/qemu/qemu-0.9.0.tar.gz -END diff --git a/qemu/.svn/entries b/qemu/.svn/entries deleted file mode 100644 index 2fb1214..0000000 --- a/qemu/.svn/entries +++ /dev/null @@ -1,139 +0,0 @@ -10 - -dir -11 -http://svn.code.sf.net/p/x49gp/code/qemu -http://svn.code.sf.net/p/x49gp/code - - - -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - -481df3bd-3408-496c-b7de-451e46197bb5 - -patches -dir - -prepare.sh -file - - - - -2013-08-23T00:54:49.000000Z -b977fe9c9bac931baf64022487a2b1db -2008-12-11T16:48:39.837984Z -1 -antiocles -has-props - - - - - - - - - - - - - - - - - - - - -1846 - -qemu-git -dir - -CVS -dir - -.cvsignore -file - - - - -2013-08-23T00:54:49.000000Z -ac4fef8bc037aa958e4675f8c824069a -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -5 - -qemu-0.9.0.tar.gz -file - - - - -2013-08-23T00:54:49.000000Z -ab11a03ba30cf4a70641f0f170473d69 -2008-12-11T16:48:39.837984Z -1 -antiocles -has-props - - - - - - - - - - - - - - - - - - - - -1901741 - diff --git a/qemu/.svn/prop-base/prepare.sh.svn-base b/qemu/.svn/prop-base/prepare.sh.svn-base deleted file mode 100644 index 869ac71..0000000 --- a/qemu/.svn/prop-base/prepare.sh.svn-base +++ /dev/null @@ -1,5 +0,0 @@ -K 14 -svn:executable -V 1 -* -END diff --git a/qemu/.svn/prop-base/qemu-0.9.0.tar.gz.svn-base b/qemu/.svn/prop-base/qemu-0.9.0.tar.gz.svn-base deleted file mode 100644 index 5e9587e..0000000 --- a/qemu/.svn/prop-base/qemu-0.9.0.tar.gz.svn-base +++ /dev/null @@ -1,5 +0,0 @@ -K 13 -svn:mime-type -V 24 -application/octet-stream -END diff --git a/qemu/.svn/text-base/.cvsignore.svn-base b/qemu/.svn/text-base/.cvsignore.svn-base deleted file mode 100644 index 1750fe8..0000000 --- a/qemu/.svn/text-base/.cvsignore.svn-base +++ /dev/null @@ -1 +0,0 @@ -qemu diff --git a/qemu/.svn/text-base/prepare.sh.svn-base b/qemu/.svn/text-base/prepare.sh.svn-base deleted file mode 100644 index c6f66cd..0000000 --- a/qemu/.svn/text-base/prepare.sh.svn-base +++ /dev/null @@ -1,61 +0,0 @@ -# get/update QEMU - -# export CVS_RSH="ssh" -# cvs -z3 -d:pserver:anonymous@cvs.savannah.nongnu.org:/sources/qemu co -r "release_0_9_0" qemu - -rm -rf qemu -tar xzvf qemu-0.9.0.tar.gz -mv qemu-0.9.0 qemu - -# patch qemu sources -cd qemu - -#qemu hotfix for qcow2 -patch -p0 -u < ../patches/qemu-0.9.0-qcow2.diff - -#qemu gcc4 patches -patch -p1 -u < ../patches/qemu-0.9.0-gcc4.patch -patch -p1 -u < ../patches/qemu-0.7.2-dyngen-check-stack-clobbers.patch -patch -p1 -u < ../patches/qemu-0.7.2-gcc4-opts.patch -patch -p1 -u < ../patches/qemu-0.8.0-gcc4-hacks.patch - -#qemu OS X86 patches -patch -p1 -u < ../patches/qemu-0.9.0-enforce-16byte-stack-boundary.patch -patch -p1 -u -f < ../patches/qemu-0.9.0-i386-FORCE_RET.patch -patch -p1 -u < ../patches/qemu-0.9.0-osx-intel-port.patch - -patch -p1 -u < ../patches/qemu-0.8.0-osx-bugfix.patch - -# arm patches -patch -p1 -u < ../patches/qemu-0.9.0-arm-shift.patch - -# x49gp patches -patch -p1 -u < ../patches/qemu-0.9.0-sparc-compile-flags.patch -patch -p1 -u < ../patches/qemu-0.9.0-sparc-load-store-le.patch -patch -p1 -u < ../patches/qemu-0.9.0-sparc-clobber.patch -patch -p1 -u < ../patches/qemu-0.9.0-sparc-register.patch -patch -p1 -u < ../patches/qemu-0.9.0-x49gp-arm-dump-state.patch -patch -p1 -u < ../patches/qemu-0.9.0-x49gp-arm-mmu.patch -patch -p1 -u < ../patches/qemu-0.9.0-x49gp-arm-semihosting.patch -patch -p1 -u < ../patches/qemu-0.9.0-x49gp-debug-unassigned.patch -patch -p1 -u < ../patches/qemu-0.9.0-x49gp-phys_ram_dirty.patch -patch -p1 -u < ../patches/qemu-0.9.0-x49gp-block.patch - -# only build libqemu.a -patch -p1 -u < ../patches/qemu-0.9.0-x49gp-build-libqemu.patch - - -# configure -if [ "`uname -m`" = "sparc64" ]; then - STUB=sparc32 -fi - -if [ "`uname -s`" = "Darwin" ]; then - OPTIONS="--disable-gcc-check" -fi - -OPTIONS="${OPTIONS} --disable-gfx-check" - -${STUB} ./configure ${OPTIONS} --target-list=arm-softmmu - -cd .. diff --git a/qemu/.svn/text-base/qemu-0.9.0.tar.gz.svn-base b/qemu/.svn/text-base/qemu-0.9.0.tar.gz.svn-base deleted file mode 100644 index 07f9ce75dc9faf280b1707dc66c012a5c4c3f132..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1901741 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

af(IP{-Lc~YINrw$jFPzpxOWXW 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 z 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

)Y7#R@%6&tkX_osy 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 y?_7yrEv0bdwq{@Jx86+ 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�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

(JygcO0 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 FvyfF1N28A_1CPIytnij{h}~b#8}JSU=-rI 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%0D0CMCwFK7Zl_pg}FvUd<#DwShD~ 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�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

9_Bsuru=3nbGPpnw3unl7hK8yx3d@0|bFz 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%0DZ~$68&U_A2qeX3n zUVLP$1_8BPIgt{G;`TC<=EZBz$TH`bYFSa-c`posmJ_O0jy#3f_7A)})cLWur5}#$ zYOmhR4HC|3B+kYo) z`kf!D&&rxb;y1HaB~+`DRVxnFinD5!L$%7!M4$*?HQupTJUWM{_UgPy$J|;)I_B0Y z(lNJI*{GG*!}{fXiPBKiuOIh|bkS3-NFP1bigeObZL?mAu*m{K=XIfh^i(U-OHZ{T zz4TPWUPf{a$`&|K<&GI79GTMSHM*O~6ig8VRdVvfK#4Dr;)2ChE1}^MM$cc zxngs{tv8_O!%)HB^fItyc%z18E@RZy+(k?^5?ICb>&!vyaw3>)6pZjtmQ43w3=#GfXY&XM66Y_Kr6&(#%%_Q5cNG8VZ6cNCpds#asF^}2}6AW+TCFv4k_HPQ2F-i0qS>6&>bgy|0P<}22UcO zk6*xKmoa3LB%6(zsFpo&62~u-kXsomzt8~coA!($#M_HyIg(hKe3Ir-yVs?Q)3bS$ zfS?|&^i34Y*7#Rxot3)OEO{@pshcL)htYqmxtPH;Iv9<0#C#b`^tQlGlzvU%mCR;EHEg@Dmjd7a*BxfglxhI zh_OK=rPB;zW>S;Wr0BdkTTfRLY~Tw_8wu-o6?|91@Fbhlm`I_Jp9fQQeKXdO^|Cob zq4H%U++;3tFtUK_^TqIA>!c)|>6j_hH(XZFpckwzZ<{Q@W_Hu`{bV(|iMH^SZBM5w zs%P~^IojRbr7w^7p4nzpwAlVifOn{fH2LY}E`cy_pSyq`?<>#;CTJdVhpe2I@zxKm zE70sZumH_l7$b#dw>X-Oo5`YaJ2nBztuuS6QcJ2B)R{0@R`~!-_Ht90B8T0xNajRI zqw#X`4nqgdZxhVc!xuTcGmR1n5A}CoO9DF*J6w^DkewK`csE&o^*}dyUiVE&$MSk- z!Hn+)vzi67dN-K0ESR;s!Q9J&xwk3Ivt&FOvL(lvf0OIkeChaF2ZSI7-kFG;4=`tC z)>qIfv_=9+U_EG>c)pyj8q>GWieSQu7E0TTA3SEG73e7XTla5yFsGUV8OE^lw0Z-V~r10C_-$zr})MrSo$2T4>5@VOeTpbuph# zi{gZ3H^E4d`C-K3vL9^ckvgYsiuo;5RTxKATNb}>Te&#I=gE_Rw@bR6HKuk~_CL2P zGb`_g-kAXEg%Qsj_i=JHgtfQO%niyAT)0j9Bj*C93WbFTLoi3rdjC7>SxHenOYD;U z(%rIIWQlhdtWUfLchki|OSRVz+1_sy2P~|Fez=y^xH#D3VLBO|&BsY&wVe848$~u< zN@e9NdRv7yZR7m)@MC=pI$f~|rHbcm)O27V*|mxV^<=DZdQtBd!s}|jyqt{3$xK$; z1iw)8tq%*3Q6SI?(?-^~19?>4qN`scVk86)=JAsX` z<>;9*2HTN!H)tCVwnWSHJ-c1)v|hDJ^)_4nGuHk)j7t|-2$4AL6ko@vcR@`zp^v_=^?uIXBF9w&` z_EGe&N|THt;QF zhD}z#*9nF^>v7I8KKle?=?lEN@!5q$&^f`l>)8bXv`;YTT(BWbTTk)8j5md89~5|CRyT!d9~5|C);5Ld<#hYFAPc6&rJ<7o&gUP-7ORI& zOSQuQ;rV79ljdULI}4E0#4w!~LWrLi+zpqDM!TE5qm+g1rVl0F%m4}wx~-qu%|bXq z=}5qh+RZy6=RX9{t~#*S1u)Xj2#94|gM3k>${%V~I;6b7`ycZwxf_$dCcDvV^ZatP zoFpkvCN|dGPdq*1plBs4(l6Eea7CznM)y9))Gb<-dY#nY>{j!Z74!COo(Cmgr?X7p z#nx%vd%|Z1mtG*SrQ+^H!cFR~wsAwCnJ#RFBwElm?f}*ui;4-$fNk7>Y`LWr0vxc7 z8*oiu-{N3#H<$}odD|8OoMm)3fSacG!b@GY(cRxdfzdSD2pQd_*ii)v33tu7p6xJH z1TojZ9E zk`~h?{O1tbMFjTxc_E6+bBBy;30adT>omfg-s13JlO;VLY;hYATC)Byrc%2v;lGXk0?45gHS!B8ApR&w<6~aAf!}!h_<=_J$~`^NP=!HSSr2 z+6FfI#grc7nBwlZ_>UJ9I{Zwa5K8Xp!yPfZ>%u(!vleE1!@ki<8Smeza^*8rg6f~8 z65P3;cO+6(4$lV4h=-Seg(U;uT?YXT02h0|!vnH$`0@m47GbZ4oO2R97CAW)r_Mp2 z3x$HusInmn?>`d-pGLMJ3e#dJcyvNSBXkNRv5@WZVa{Ym)_UQFGe;o1VK3ziH=IfL z?1sJc-p*tF+uP8sAx|)<-**ZqRBZBp7Akj{3JMi_Kt2nVyG{v0$2TDY*nIJ+ArUAz zGGBa(NCXOw$L}#!FjVH&kFB#;Cm2yMx+>w@M|>OV+onE>(j(*2;G=E(gnGgiuf=FG z7$@&0ql7hs2g~eHDY_C@0LhVMv0m|Tom(v08g{)D?epc(Uk1;BwUFZ2HejZJ} zt38h%Kc3iIUIiwpR#JrWP>)43d9zJhYPG53Co7*m6Fx;8QPA18O~Sq(u1dQpR;`=~Izp>5DX=uo|8r~ftxtpGd9&npn; z6{zMFsO1&d%jkx2jvNMb$sH(2E@Y3nbBozu%s2?i90=<`BeSeJbI2`*rvSNyq%}Uf zGh|8+Q%{^JXY==D`LArLI2^IH+ZCQV7-J2B|Aziqs@2d!t7ZX~ae2ENlq~>PHv<(c z__FO=8(OW4Zs%-3PC32yf3@;Nxi)}FvRKY-|61 z=_;xSxGAy!Z2n%4#;n?mUPM*%J|)*LcUtZ9pX#R^tX=5{Eg@>cF#DdS@lm&JjZc)O zh{lw=x9n|tnK%)qDW*H9D45KP;}OM%j)E$4o)YPlxtkJ6V17p>(gVM!66sVerbPOy zeOV>a--e|``U^QqBrBGyM0$%kN~DL}u72o2tWY6WiFA;1lt?U*sYF@@TqV+1AkHgL z%_~sLE3lW*ji3@~77Htp4&D4pq*E-YM21Ti;3U5i=`Cg}k={anCDP>;TZuHO=T#yd zuC$a$S1NjyNC!-=66w_NE0Nw}0VOhAwgB9a5}8r(bCpPE0E;M*4n6@TGE~l1B269% zE0G~&9VIeU(4$0p+qRX+K%q3h7q$`^DkPQ2fG$x9X-7vp~%+g2k z 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 s0r2A&@+t^w!Ue^_12_O>MGEBJ^dKiQq)-d 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

H1P(mPX@6ym(oV_HmhRfD5~V7 zU%molhsg@a>}7n1=< zDGJf@n^5H=5>`I!@0}4Q3@+bc`0-3ORjfYjMv4D0E{~Ra1y!kVW01)#FBRV zfMT7TkvMCKw(!Qh)?nx2M@YDG?Gz@c;4!JWDKtI&59LTMgyY(O?qVu*hnmCmQ6nmlR7h*!-KMr<77T`|1;=A5OAk=4y?zXI7gsa%hGEqA z{n6S=a@oc{C+LzQnKnvvT^sWv7`o+V;c#f;aThm(E9B$*nSoOpiSUM9Fef`4IS+Rq zU9_eU#O-UEr5Kn4Ojx8l4hOD_81n{E3h71AND>8*KBLMcj7jZ$3fnScrqSgTF7O-Y zTsaZx?3i*!9^D^~5d)to(6wAa7emrB$}LV+{bTBn?^3VgQP_8)!C@Cz=<#(LlBBWp zj4`_ym!471?t08yPe6G*i773YsC^R41sw3?*^+39H=m1*5oI~E?%KbUk2F*V$PQ*$^{KjE>(qOdUu>WLw9yIGE|h4RG*}0b+s%p zE*G5_T!)jE5V|EVgkabX$4=Zk06Hj$($F%|V$``?Iw`XFxLhpBY>1Pr$a%-&uJtat z)+>o8{mHF2nT(ycg^?)+<^WiCRwKPQFR_UIS()9LHQ^$YnG$9$eMR3an4ooM<-*M$ zUi&gTxzDtG*Iu)-#TXsno1|$e&*qAK7TH@{;N*zoj%%SID}gv_=#Z2OwvzTjdmPy^f|5vG$@ z3d5`EsMTr1zk%=Q#>bnLt7Ba}tjMMdFtHDLCf+#O7+s78k&!K2O^Si-f<=U`DuWIg z)%j867z#SR_3)PBXuxsSyBr1WY_)c_*4VCFU}s<&7Z=ji$|VJvC@E9mNR# zVm!Ym^HZ9KeDt~pSAdck6N@2!kt-ZEN5UU{eO|yM-irTLs`jK)hTyBmhR5A>5xI$gP zVQ7PU0i9>Pr;S@$E~6vH0)A@L>D{BE()_^kW<}-C{{=BE_(ghM z-1=C1opExYT`fj>!#1lTjL#j*p`9J1|QL z68ocZ_dC;@j6wvgkiwj5sKOzvzz;At%^!vqqwmBH!*3>e-U}xo-2$*k{r&?{+3$)c z&GKRLU9vw2F2e{P0SjPmu(arkNgSyr%v(WvLW@t*5qNh|0{Em-Ef-y+J!TxaGR~`w z^Ru&B-I$qz+-!c}LErYf{5mc6w%-m_`C#k>V&&Yt!(<;MH|ihC!O9g)k>ok|h|2B6 z*YN!$A$%-LmDW0*A6_@5V&T3OH}6|i(j=%KN!@=7Qun_`0zhE~W6Bth9w(0JomU3`l*F(M@r9sRe!o+> z3A^^k5xD_ne=DD!w?35XjY_S`01l;abT2Ufsb7^=XJcdIH@l~k zU^uy zlg)(XEkYBhRxFUH$EV7FMgD}8Q+~h8eb|qHCHKeBx8DtJSw`&dH$O&+u?s+%?QkU* zr3XWHaX0ZJt&x6bE(ALM#k7a30yBtSW3J%9&Ku=csdk9}Is0r5WEid^T7dtI?jWHP zM5v%o!EX2p8;E zUPt3gDEuTc8$Y~ZKdt{XvlU+X#S5)n{RcMn1FT`aFRD0{B+aptG{#@FmHMThMv&!s6SoV=2s@j9ZhCmJm}jE>Ar_ zV2(@DBClE)GsEFVbR!KsKv4J~X5x3UuibvJa06fsF$(OS8rY|HfZW9q{y-{9OnC7k zP0%BU@Z)+u7r_-sG!1WqzcS>1q35)Pud ztDo5KzccaU{laa}1?`FRXvH_$3^1p(I7+sN)LjcNTe35iD*_}~kTDx~fYVtQRs_J2 zfPu5{Gk5YjMIQNKQD=EEl`ug599VDxJG(cX#!F5Fvs#!11PRi99g~q%J(_f%*+$~%eOZnF zJL@7eD#{x-aTCf5`xk#4vT!;f>O|hz13!5amF;RwNf7JKd27%5kS^l%zEiYQ}L)!MDrnq_k8IrKS|NK^~b z%E&l*g2@3q(<5>jCM$vKI%A?=AhyIkg{?{W$8;%|(O4uE`Mw-;jfh+-vfjLY!B>i8 z<-r(Vaq-n47^xGzB5$@b+2>$$D61DYoNN(KP0Ki?U+iHdz3kBhk&~AUM^+mrH8p4kjv8U8t%nZGiV@m+d#%2xY}{*mfLpO!sicO$K2^#jBC zJC!7l?8P+bcZl<0g1Ir!%EZ7^ib2YXMm1d}nwtu%YSeBJpQtzvOc4xMtoWqLP;QJ5 zMEw?VsHz4bch0aqG0$c+Y;P zUmwr(UuR|dr48v4t??p^_x0|`%*G?l8y`)BPOIyClj+!xfJgxRRyk}n8fE>Y%W-T` z@UT*St5s_peQMOT7TujDihWV*#f#C?B}S-L$uJPjR_cF?*u|X`S2A?1GDMzT_{oh? zDr_s&W93NeN_NyIffstAicnC*d(`Wb0;Aq47e8?ej~=YC@7?YvOC0DWE?gx_dWp8H z#GziI<0{dpXeFY+)rMZ8<0^4*rjK;w>P0UR=_UMN6z5>zU=xxma-;*4L1(gY!HKEM zLN5b9TN5O2^izgq$mbSQ=J;_rq({XuM;`&5NhTLFCo(CYOe!RkHu*u)leUsc+sUMz zWLvw*q`hR)E5}e>!*`57@0dV-(~-92NZWR#IVO>J%p&iYM&2=x-0faYLriKjM1GGb ztmIbcnOmXf+6ukoR_Hml0=?R9!6=@o++SNQAj9jeQiB2?{zk|>ciY9!QehsJ8>N=Q zoAm3z_;qIdYRF$^E169UyhtSu&rVv6ca@_iMPba{dMc;+8L%wR%FZ47;h$jWg&9Ma zR}+$qa6bvd3#V=U+E1xUq4-VR+Xv}@_@Uk5LPPyp;nna2%0-sKUp#Y5A z;0NqymfwMYlTxl2@dq)|pNa&RPL0euNQxqkaDt57H_Bf6-pDKpG+bN+wQk5T-30wU z$_#*9?2}m;y70&Ao+Rw7@ww4@S1z7asz)`JG$m3UNtBV3G=+1O8fV3NDP^5jq`8R% z23pbZ#G#ft)QxK>_fF;Ar7prAUxVZd^b$+ZO02=6Z9&DG(PZpujlE!dzs&^A*;xWG zqfxsBrCJmA9RAt20j4iy=`sxQ?bxtGY;oZAgNQT6+G0t?4JOkGU>RUP&py<%n)$|P z99{<)+5xr!NqnKnK6)+J8+xe^5vI{;UEH-uNAP5KJJ-7fHuf0|SvwSSs&tpHGD_BP zmRqjj;g)@-n?Pe^OKW=FblCADd-V%nU|0Ho}81Qi&SnX zl{!PI;aQ0`2yM?G88ReBNZ17qR+8}?NAgkXXNT#BXS3kMhB%u51tj?bd-jacpF8TW z{AN<9%uQz^aoRHcxWR9{z=JGsO?lUtRp=dsPJ&VDK~EX0dNZY+bN(|a_H!O}G;^@e zI+d^(*Y{gXYz`d45<7!NthR>LB{TQ33-cR!nwcRl z(aAYWAtme|rtY&lD8YbCawC3dtDJI)fjT8Uk&glEIUv*F>{ z@bGMScs4vd8y=nw56^~&XT!s@;o;fv@N9T^Hat8V9-a-4X*9BmL}Qg1X{K}zQ`r2> zTNqscq|hf1fF)*7ck6I}Tx`|IuQSPXe^ERNz1N5h*?_1TQurhk)hk^L_wk0* z@R!xUJbr(IkIeXT8?QEUFG)deINs>;y(K zL_QDt#+2w1!^QE2u*wmRq9I1XjzVae>=pN!A3*+C8Oau8C!)nQ7LKWvj5oo-kA)#) z7Djx>`rah2yO9Qhc%~#q;8u(y@lF7yDJ2cC!MfA_8npqX*~d!rUG2Qdiq+5TW3gT@ zR-2#qq4eYumD1=7joJzZqdrFJgQ<!o*4r+82~sWd;sMA%WKSuHmj z?5I{}MRr!KH!G#{lVY8no!8H5jq(O#4YDxwsf8JU?$TlbEIa#`tb^{vC6Q$vBq|G zx7n!|MXZSKp-SEWc5kN#f1Vauu8`k+wZ_gHMV!VpQA~qA6#r)zBSW= zFp&h8ubnmqy53Bi4q+>F%rr91x2oPnh=7Nf8Yh!=_r~Ru)zz0TWyCaYd3btSJR>_% zZVG@d!VxTF7wIX7Igs+M)@ZVDh)&3Gg9#6DzVxVr^aEKQkZCm6c1o}D8N)9Vkqc|4 zucp2~TqE)bYgkUAcnR{|MfL`wKK)IpI257o6D{P$`*lg^X;Z~w(o{f>?=>IOo80Y> z{aYN1_zSb&{Mg3-BP#;YGY(d#(6AWr#%J|fvsEt_57}SYPvf81YqY0KE%>osX_m3% z&AgK3PvsI8ycGpw>Qm8Z8BT&dWB-zZui`ORg9-x))wZCa*2|UZhoX4Y2lI&^ZcxqQ zN#(ejfpn$B=#WVrcJczt>)O>0kgk+9yB91hruDB(46EODaQq(6I6J>J8nX;|@C81DNuW*^s7In=v)ip65IG{M_gG#euiHxw( z9};$?VtX3C6?Cw^adoD%O7Ve{GcxRy=Ix@dTZg50P#R=$2J6l(lmhJ(VcJ8l0*!0# z8b}6J9B{lE=@E$}&jvxK(^ryxb&B{ByBBWW7Sy1o-+**i-e<;qB7Amg8AYQSlIJ}j zQbza!>a84#?sQHZX$PeL$v_bwSfL+O4etRUMEq5<;U^cgW3Ok@1Y_Up%W1h+doBq< zq=37wBnvo+LDLm~cC1FiE;^ES5+F20>V&*f#zY6bt9!0tXqyzle=t~&ko?GoNIoN{ z?Z&Cvr6jK~+#GQ=%}${w9yy6!gbazGmxXYL?@}QDqoBk0Ev&@|?<28SCH@fCr-nG< z4i)~8v)~D))QX?|B2lA}KB-Zou z(Nhw$f6-R#*_#*xiv1wBoTvi>qM|YV@PTD4#Rf@Zv}v1rkBi2pok;s;T$roIA=5o0d1pjN z%kj-Fy!2HU-eir53opK%jcX8bv>;D-L*j?x5UC;kYSfK{TP?3Yy7XGDEM5?CYBci3 z?L;b?G3{)LI_g&>5%sM~&Q$g{vW@_X?(44+n(xI(A!h2Ua<{<-D~ zE%?g6d6LjZYl4i#o>^F$VHch)(XdN9q#F8()sX;yK!CshQRP$l&?XuYfUnHe$@%k8hMIS^CO_*HI z&wdcRI}KyDa7x|Gq#>Z^QSdK4XhH1+J=^aEQjPG_`sgR2yRn@ZK|_E2>t9(3NMNrI zL~+<|PseaUz{axWDMDHpJD^B9kR$qzwCZrn4E#YjzC%jEOX-!AMfh?r0y6EE$Uu4! zC@5;)e!`;+e)5)f$T@KZ+}tQojrN@O)7M|)sw|#0CKA^8T>!YZyr8!-9h=VOvgD32 zx2?@^@sSIrOYynMi8)wylh~1;gn$iMgKgIM?%g?3ZS({6SLxxz%v;xp~&iF z9Iw94QpXgF8s+5Ywja}qoW+PG=JMn2NJwXk3?OV;H~)v9dhDcdsD>9@ULn!v25IA?jS=uqXS`s8?77br+?o2#k9C2;qNU$g1mli;gOe^P%mjzuE#GppMY+ za4~mv@wwvsfS~-l9fL@Bth7F|nJ2^+bLlI~IWgW!6e<<cM zTSq0CmzxkD8z50h?+)AE5Dy2+YSltq_-zkQBqj)$;gu4qXWm|)Jmba!AFqRJs!6xg z)<~DnXe6HFT#=44hM%j%f0kIvHtcSquKO1+m-WaMce zw}G8@YUa&g9_-SmH-BnNivIPX%+*br`w2Hf`fjp_yQDhO1W>Bdb_OPxS5e6l7YAo* zNpZuxnA540e1GMFET<}#SFTVEXM8UT{Bc%a4Q-j-i=uqgYhqj2-YYX?T`LkQLaDbx z*55{|2{p+SSoB>&OP1j0G?>rV1|4%@D@nLG zVDw!TJB*1Yop7p>MRoqdN0V%rLZ>gQh7BF(u@=z;q}$E81^7w3xdqMUXhn`h>C2r{1H}A}~{W|d6XI*Dac)1&pFb42h!0&TTbg8>f5G3i+ zEa&}mPt&MHFA&Mx*cxBcjqe)Hm*mRgkQ;Y2y)8$kTyb64h3^lQ z5le@U1CawtP)t(YP$82f*t|NzJ`e6~tAQaootQI<4*eTZ)FesxWxh~#+H_hh9&Xkm z_X+_Jg%aD0!l#ONhH}Tq24a$gPZNm}IXfUp;u*yQrXgy#MckB0V~8b{+52|CC^J&? zkas(sTHRlFARFO(vxap&B%WXEgqh+b%OoMW;V&&eV)NTRa1y#WVh3c-=M z`@X?#|4=6B;@WbT)(y$UOcE$hrwFJL2W6_ojogF)|3CWq)>nV-_kZYe@_W7i%kAd# z+llvoTicKC|GvkE7BZ+iorJ*SlH3T_9$hJ*IW);((1Xgro3u&w;;~+UPtUj?(hWQ{ zes6r_uN&Tr-1d|0U|A*J-C2g*m=yUZUPQ0=A1( z3qiy+5TxNHB`R9+&~4j>ySV3XteVfY?xL5IyOAH6@2NTgUgYziV!2;?C7*G*o@^x^ zg~iXcgjZMutKatr0^y?i8kO}V-3fq&Mkqq}%F{e~ypFx_L;0gAT%ieOATZOQ0e3pV^)8dh z8i&Z(>mwJQa8nyYB7rw%gh#-3R#)Il-2*Z^(U}00t0$!FiL}iK&v=+9eY3%z+%Y}f z_2bTTlo5l+TrUzLiDy(!ZqqgPbi8fGpE;13`X?k@b~!r)&LGKZBqdk$qa(kX);p5G7_gugOa zI-VoHO|_TjVGwm zV`;gNorOkL2*tc%@qWaFHD;EF#h~uKtgdJdZu)Rn$f4;>q*xhj=z-6G06yj#y8@$H zs2m{~z#Yn)k^2;XVO$9)_d+J}reYkHeV%AMtF;{$O%z)vKQr-B^PoylRX6EgcI9%0VkQw=HY5XWA_GVh6cafJK5j< zRF$M|y>>TFW_EV(;hKp-QkA4qsZ^3mRV6ksDNp9ZsM`lDAvU^_^$|0cALIRzKf!11 zD|}VWJcnQSQy|S4WMQz4CK>edn-ettrXmYs+S%hyhe?yz9LEu^EmfEJ$&|+giUi~n zL0+|VSsv4o;oABV3(PX`(YPbU^;5S6cLBz@pp2#gES9= zLHxa@WC~aOA|TPXkH0mZ&T1Oq4dy_)`<5nn@tJ zZ;-(x)L1Q_A8g{M$1o$&rQ~{R75DdaMErVG7b$`NoXhVO6L$X@+hLiB?#cyFIx(3JQBn0QTYu%bY;Pf|-e_WmP9ikNM2x2ye;!BCC+ZEYhYA1T z#snC!>P7fI?FRix3cUlWA-+`PM9PRJr$H@UJXl2Awu?BLqBj&0HP5`C*5T+AX}(a| z>W+DA;GQ*RQHY>P?PqO37Kbi!8Rk>edkH5`4yZQJN(yseo0&?Nr(XKHjR zv(f>V*v~?2HmRvA-d~>a!oRz8`Vair&wtqF^=s9Ueg4y^J$+I)&VTmyen0>DH9mg~ zCv&_grr@BjlRXpvDV=AmuGaHUbf6&}d$9P0c_${{ir5%{JXTSBJ6g~wiBVQf z`x~yeifB7=5+Cs@0tq+@mU!_>zMYpdCa?VqbeY7wCHZ)4vK9AV@ehf#1HaGJXY;<8pN5H`0>W&>$aia+-^a*lX$I40kevk(j z;88i#A-|qss1*M?7_&f}TsvMv#XF7R%EPD~?6C;b{G>=BX&Di>BTX3@DPto=#Nm+2 z7%3voh6H7#&^3pi7)r(Jdyq1UVKWE+kMRr>O@ZKl1p92fiA-J6llm`*^_7otzn$Mq z7Qy4m!mrm!3UDlPtScB0eB$I?gqO^|nMHPp#CdTNEEkZY^D)}dGSgvh4h`~x!g=9& zF*c45TN;j3Iqs4otj>em)q$l;T%S8SYkIL9)CUskbq{)zoUXQSK`j$90~O3Tn1#rk z=(H}J`>4LA4~r7g$BC1BZA=o6_O^6#K%bfj#Wy?}crrQ`o;T(g|8c#)r=0j2JT4`m z-%_QpzyU=T({((QaNuvP?NF7C{UDiL)>#{m4y4nbO8#wC3ns|K72|;Uo0xn5gMr>a zDW+v4dHbsi?nh}5C2Y>V7!h{L?G1I<^RI@r4H70Y~0!J-QNRq%24qi;RPTh#8|XFOVnA z_rS`p=(e`cpCXbQ4m|U}V1W~v3zF23fg&4=Al`@sw=BW@I+&u5L(C=k;6^y{+xB)E zVj~l;CzEglI|;hs!HXq^!khWG;cPuaMBf8;thnCT|Mb$kdA$4PC2Pbt%vm2-Sk$)f zG#>CiNvgtn85r6EHZEyClOFi4A0eq6Jp&Yx=#t4Puk9rNhmf^c&g7THIBFN`$p>h+ ziEzF_-5C@uczTH_aNvGOL8O%whOhU*Xm>J2YLEr*482Fi`J#gGMjHWH!aLQhPh z?H!18>As4{aEBzoHIsTYjws04kS&Au*orJxbk#MrFj%c>sKCMrQm`~!wil}L(<@$%TwI_|E_NtHKr1!6pJDLC0{yWHqpTwA1Y8aVh$#{*&*MgL=sKG`YV)hr zDr*_wuBTrc>DL{LeV54FO^ZEAzwU`fUE&ggA)J+1?=v9Y_V#u~U%{BpTV~gD)q1s2 z!5clkGTCF*Q!R-va3yrRXhZgC`a$;5S#oohE~AV)S-{Vvbr^@;d&FZsvSpI*R7WVa zs3EW#jexqA>Zl~cDaCQ*qlp#&v<}t*hb%Ll<1&#)@Ew^L16OcnCRDTu zNjO=QDw{wn7G0K~VcU^$C_u;FKXPPRX@SI1hs>JcCEJe}gC|NXR~dyI`zKWKB+8?H zh^i!0b`Z(?{XLUY*nI%$i$l^9{d}<2p!z_;ljaxklpIRmzzy8sY2&O{s;vLj(wtxzHRq9 zM?W&(J2gF(IoYYFr5S=@1WO8RMyo_4W@lfnSCW0NM{S`BLBn3G`463Z;GdttN6xW)c48;)=ad!23p!aYG`*F8=~De(C+P; zX!mxDqZJN*(p=%}gQa|Ce`@gabLD|Fs)8F}R6VNvtB&ifF^f6tbaDJ5In+4&o574Gma*RYx3ZhN+w zJ?aV_ucF9ZkuOC7h*)v2`))*c!XbgRpBRC@qGyO1@S-) z=(T{nY@p>$M9~uFtMGCit-0kZ?7QX0vHRe}9Ci^bQD3L?&G}fVe%nhc^Je~?IC18Y zFO+KWG=yqFM4}=jkhcnEi)e}4{)_cw5-iyw!>-Bcp4!?|L(u zjq{wvoACH5hFB;f2ECd|d|Dwn=!k~-g=Mv{MkFSn6poSU?@5oRRsss`a$d-<%=j1@qbKzw9U(NCN-NgK zpvMM^PGW=k<%-T_eSQc<7l_Q$vzw}t>IzVRL}hW5i)3Aryhx@p*mkyV3G0^dlO%;m znxH70qm4O++X?6VofQ7mqv zV1>gcl}huZc(wB6vX^Gk$oq@g0Ph(YK8yNsncHV?NxkWKeZjt_*|7NSbAbelTm=Ys zA^lX)fNGcExv}8k`3a&M7a~yS1fr=056@2UOkH?DgA;guvf$y_37(%6JYjO4aojz9 zMIO3Qn(XZ=RZKH$m}XVL0{U5T*?K+A>a@6UrN4M)&+IsmyB+o)cKaW3T=sQrOfv0% z>U)jdT_gV6Uaj`K{m-xQ;ql+viESgSN5^E+z)wVf4+8gl5V+riz!eDsXTB7)1%|V} zJha%+IReA2X(x2MDjFQF-+6V~Jbs|ulSA5H&)etRr)|B~*iBw3LQCjYLp6U%Qn~dD zW*N5$%szs>_ai7_ua9MX=G0%onquI&u`l_uVfQj*q(NIn7 zYaTU|JdJ{^TaNjDdwS#F#f)3|)|HzsWN$^-Zi%&v{6ydxLAWAUhT?);ed}Z)3i~!( zVWf%=T-P{-G5UC*!6tnWUpS00rXQ(;d}usQlgBP>+yDioG{Lb>F`=!XAX`2C)g`+c zlZQ*Tsqw|2;mHHYH)-IMCqv@?3URSZ9Cq2Cq~pz~aj%uTPvqtn>yh+UQk-L&H*r`w zqv#$*=4Rab0Z9A${On`u&449TlibefK+T1OH21IP9W5JEBA;o`m)>d;NAOZgq9G!4!!$gYKDLQCAxIL4Tlg2Bb*&gU+dz4=Hkf_gv5K zo=ddvz0yeEdzI$CZ=Gq-m?GsL_5Y^jLrR+ec3_STOOr;o*FDlk7gEyvcb(JLYqbC+ zNpq{Kv%ZA=T~9;)t|w9dM{QO>0?Vby=C?xf(F4i5^q`UneNEJu_wp|XnTQ6;XB)h8BH;nmP<(kr-~27C0Td3zOL z5502T`}3c@Q1^?iq5t{0N9D>6?!W`Hinry7SD>Gr=NCH-dIc|6Nog6r>-G-&MrS!b^n+lhXZSH`F-7#*q|JM~m~J!zvx@bG=hIRpNd4jk z4w^Wgfn5dp^0RWabj0gseJjU1xmYhO{NT#Zp>t-~!*Lx{ri#vv8RKOgExH4pmdEvN zmLxrmHf4g+0838|8f-XiZC2??0sDN6#n>Nc(|V(cs-bnxS7V|&Wb9X)sODrER~Vyz z(R{U{C4PtnZ~TJuHMdjV&w80kITn++f`s2`RE)`M&II}$iMgPr zGI643iBJwTJ%gU;CFxvyLz%_4?D&{IO@Ljpnt=OSOiAZ%k_G#1wJh%NHUGl=ICUPt zFae2RqrswO;2H7FRpfn|M>p{{-Qdd)UnkL09swzoa2R{x5?>Ns`*X!PG4C*th`mtT zMq-gs)3$J)SySA82ui$=cT2s&N#|7VgNb$t2p1u`fJ{idkl(V{A=WCyT80pwM;8&= zii9la=>_`yfHuOSa}nnB6f1zPT>Dd)QrCE_MOV5C6Du;Xk~D-Ye^MyP)rq_*A|ah` z^qnzlT&CPPvqa^5*K`m@bh!O<%?nXR%`l4d*Wk(_p9P?b00AgOcru@n}=Ur2NWu5bqs5i?xIbN3cxnOG(Oq0$s zKMQB%oTrOT2x$`>>u-ZpM~QKA%>#cVEwJkSBXvh~Nw=V6MoO0@k~&5wY_V9jQpFHA ztGJW0?pCwT1Gy_o)rWc>fY_RUF4~HJxHPi_so~DSdbIctqjLNRx}n04e#Oajl+%vi z9)U8{gcU`et>ly)=iC}^Y6UX7isvvapz1Ote|MNOOPnU5;18!$+JC@EZpS_gYsT$C zSqh8d0t--+-2xqTmF$!kp4%?GblsoMBT(x%sGA@v10P{?m=id~XUiG!MmZ$DHP6e}YP-+tWm?`Q|6X5qat^Pa*J6TQAZ( zbzbx*%XvM?8iYw(X0}GOlOwe>POV$eiry%A_{^CtTV!;>2`E-1>3L|mJdapYD;4I7 z0~@7Z9LU$V(srKdqxNI5RPUT{x3KYQ3~No588|%i*7K3SMiV4qzRBA7r?FT5Q;g?n z!EK0P6)1#_elSOGlX*>|R^)m-d85*Kl{25mD z{7+*mJE?JzK5;pgT5=$xZzXb!w+Bjn0*%B6mBLr$KCRoLki3JyLDx>42j*%DD_R9y^nyVq0PrdoPw^l*WT$3x%- z$yiAqmp^CiB1QWrWNm}KcwrNhj6Inmahsi6;7HiNu)vUdH${ElKr^^$jv1y=v@>;p zBRbw< z#5=bY590tVSCO@Vqz4boZ;uG(r?lWttnYY=tkNLW0aDEaKPkyc$y5#*8JU?E9P-%{ zyDaYT6Dy`)DmG4{x-xZ>a1IG8-oVm9Ly$~oGD&3GdPyeNAwX?=Qdv$S8_(Hx|F<*misy2{*dKpPNDT|}1D+<{MRu9b+D{Q)= zPLV3b3R3)ny1uC4<=%3=Sh;jIU11ZjIDiRoIrZ#PMc`rQbO6iT`PpFDe%~3$$9mkM zhO{dc3ZLSE+pzb2gxab(Q=P>l_;Md*F;&y08`pGeaxVr^!%$^ue;YDVEZYTx?upID zxSX~9+o~6(KO9>eq}TFJnqos0q_(lJs5 z(%>6S9G!H|`YBaQ39@BCUK@=zNLhqZ6-Eg-x9&(_QX7age52NVqmOCTI$%|zgXz?hU`!5yyKiP9-BCU#T*#&VEkZ;m; z3KktL85SvB<Xw}|eneK*_F1$=8>7VN1YmmYKKvM%nwg6KXR3e~Rx3yxl7{R$ z6<^4&@HQ2ea-GV|Com_oUZvQD5b^Of0(aN7q6m>|P~#S$La=}YOgIN)9fxprY18g4 z{GGKg(g`6SLWt9H4rW!ki&UxYX^U2=oPS7F7Q^H`b4{@6{K(fc0mu$m>c$DnXGy*& z!9<03ZRTAmnk3I~L;`d9!<@lZyfV3E8G>+n$Xv)kw`&#LA!2s&ywkMg#b;Hiwi+p} z5A<81;zk)o?wYOlX_EG$lSB6phKEp-Wi;at?obx-xx$WWWmN#y%HWbbXbZnFIGEuC zHW%~phux0{QV#k*ol|re=|xh4=k`8`(zFHM<;^cY?0mGLzn#rEdgVk4gO30nLT_u6 za1&i3HvyNR*DRTnFvg>^SrUI$}KPj9KKR2}QDQXBGsxZahk zv@uHw|1ydxl?z6Dvd5W5$dC8?dqb>gc+z~;X_ZQ~TYO8cGZk<(e=evnJ34_I4lm;? znWra|I8hS=N(|J*F(r;EQRQ&-Gp;4YW)k`y*Grj6==)qpZzhe*B;QD4J_3z`OMR@F zck`0s+I%=1SvtynQyaY)`eK2R@x+8DMm$2aDu8_M(^-k|#$(L%XgX&4oSHmZHW+7U zj?AUq({#n0q3Z%Ej)$>uFAU$UeZn#n5d3rMr32lNuM7dUPC3oi$rAirkL;DO!jKE= znbbjE6NePx1DqU=g=YMRgoK-53M||x8fPkL%TqsQo=?zs=p44hA%+7;-)@RMQ3x*&*Pj)iZ2%0K zb#NJf=nY@>KW@Vk3|j+?##L6rmOZLGj7M89*akEk%~3v@NdYwNd^AA;G>7?U##v~V zyfufNk7(MCwT{CA<@;&*xJdbzXG!^sMG^dI`M5~=m+w>jw?+D!mLC@>-%87mij;4r z<^8Pk$vO8hgq_bVhe^EjI>DC9Xi0`*qL$?{t9ZB&<-#m#a;9qKGu0@IsRHgfm(`dY z>})dRsb-Mh+4^Ia+>b z2>OGPge8UNLsa}ei{;`lVD8Q^)KfUR;(=rE2qzA<`LbbieD;8^1+=`BvyP+vs$~IS z8-2Dok%~p~UtJbREhaJ@@(X`z79I-C(Zqks8%xxR7ch)E|FP5O8sQ+9G$C`J`2KNs z5un2j=FKt~O9y}$Hivw~GUt(qoKAFn{Vc8D9ClCpgJ$au1s`VN9DPt2xh`2oNhcy) zmUs(!*d)Y7B_Z*9Gm%uz(&q<8!>0kz_0HK^q68iY>33BWjoCHFpf8NEDVp+dc;0X0 zLgYPssGO91W1)e1p4jcRdlell1xk)^weu=Q8SOor1@1tOwJf=OL_&L8GA}{Pw)WT4 zit#F&={AgKlUtf>=EboyAGP5_BEz@(gEWq{m>Hl5Eh#!=iJQGj>J2OK+*4)}PM2hc zpvO8&ChJ7vuy0)MZ>gLChOBoPp|{HLI$#~30AQxnC_jFb@FAMQ4ad<8W4%#yXz_XY z(6beyM|aE&_bE^w9`;C{!#=Ny{=c`o&lfJ#bQ-Se@I;>aFljPEL=tH1fV#` zs+ya?kE#i-M0m3y30C4YZGjq+)kd{w&3}9!YWGQoZ@LDd3(bEfXr#_Vi{eB<6vARf9vS4bA3UPX#FWV0lpJK0|kg%Xxan@ z3Qv#2{huoTh12){)Nc1{ z)HzF4wcCsRC;Omz#8+rd`lzB+{(Y@NwV9BDBYHSUY!uk_r3FdDg#?>68fR3$N06T% z42?@xH7O@tTXoBK#SqZY=qU0Iw2LWqxGGiC z1xix8T;Zh!9mYj89?Y4+bBS(8ZSGQFSiFwpGfmg)xx2gsz7 zr(YyNt*ODCiUCj5s!6EEM~__#;&QdwnwWWoV!tqu~xDNCj`>R^or1fY!Ij*&L%PfqixAw9UDbI$o3!SIzGf@7r za}}=u){H&@V%t`v2v$0Giio=P6YE#qVOiCY%(xod^wXdyIiH@;@a^dvlcg^Zc zHLH7QQ|P{%0-xPSm69WMIklneGul^i=uwzQHXqa+gpX$iU#C^W-T z>W|`z_p`TCa3-g4aROI*P{Nf$;nUS@A%(G)KO#qIc%qspvmGRyGWorK)oyodhlfwF z=5m4v4>4J?S=-~sr4rMUqGfnF#5L%-w^e7>H{&oylVxE-=#8#|(I+w_B>9e=;uAH! z-NZ0JW;Ku~8SEwfO3(b+Au$xgrI{a1v$X4A8BXqo7@0*+*}B}jzt6u_ZO-{qeenQ4 zHs7~M!M)OUat~RlZWWKV#l=smkZO!Tt=sg(F}n#HoH<$=^I36B=yJsNkh$hcYpx`t zgrRD&MttTw?6(KF?Bm5&pg#2#l;$h1q-{xbwk*pu7nHMKWb;h=iV1+GRub=X(pwb< zn>nZ}sO$zOA=1oHGF_8nR}zlq1mL2Q8yJRo_SUWc{>`O5)C7O+F@>NWT^loR+E{QmUf%S zN0KdN@+A4I7*V>LC~U}i_gdZ4Bj_ML@!V-(Txw<)a|AR7A(cEVBA)`moSb~o3vRw! z;IDF%NT1=HHH=3?O2g{)-*txlAN%CapglP6otDbA+h9ULz-m9+E&;vou>}a!Y91dC zUpD*gO2xp}8|0&uH4Hmesn>%m=#tv+1x5|B^!hsVz2#F_R^Aa&mH}`kMIS1KiN^Fv4@cR7ZrP_-z^aA}D*Y{wPSG#RIg`cq7vrtJR3B#omB^RAcp-Lq= z%CWe+<-8Ps*kv(NO2)ueOO{Sm(}Hs2e`=%V+M=*0BWRM9mStoT!gxQ@U@}!@Z(3u-dfxQ(8;iu*1mz^utBd>6|M=R zIHn5F6(XuE86b59q+SH1p@1}sfb1wBJ4HZt6_DK`AWsyKCq+Q^6p+0lAWs#Lr$s>a z6_EWRAU`M|KNK2Db@=PW#$RE8$)XU9!U1717=;DmVlWC1OqYdV6ed`V1dRGTQCSx) z_)yCm;vE%Yu1E+mBSFcZY?|QmUE}Hs@oaM?pItYmhSQMb?v({ix+#z`$rjcdAmbXV zj7d>t-N;O9T~XGs#QhrfwUUTtR|f>>u&gD6OSah)oR@BBK@%u>_q3NqNPa_^V=?>i zq4$k)iw&Dj+z)SRB`db6yw%OYS*!28tkq#{!0?Ab?Co!1C~pr|wM%+3$=fI!kf!#d z!hG~!PmL=bZYq-;(^zhDoF=56p^`pY!n|Wc%@0j*(AF_?AgJzX(hDlpn8J3`SF$U< zv_h^(v!gZA;vYwu@D;%g>T5fg+QQ75?eY@BpZIqdG(4Qwvvk#V+xTm1PF6JH5e=gLhqI58eWjJ~&J#=)VU~d+;*g93O;2!a?%Xn)eA6 zUedAnb?tOAyt*0r3&8ODU8{M(7z7jJ6j+o?r?a!(YF@t%P?m~=O*3EbfY z5d&erf9^FBKuIZ1baf~MYu<9iE>EO83VsJOnXcojVL0+fSHW=U&o2YbZV6^9UAuU? z2mJDKM8RyN6Em46Iu?xS&ihHXOR{1L<=6D$u%ze&R+~z(_>&wLb6i>C6)s}T)(Lh<@SeKA~qPoP^hc8&`SaE*y__0H;aT%Hx zVToVD(sYB%m4e2k7FH^5UFu2qB<9eetgeG#wr*=xvq&vGQAIJ%bStW|Nv0FUI@u*` zZl}o%F{gpQByZ)on!@6r#4=Bg?m&4MNAvGi^z@8fRd5I1auY!fPrS$2&j72+=_)h! z-PkVCHqB`T_$?bH%B}?QV@`Tz?50h1>QaH3t|3#@B|JGqKdh1)))+^0wvN$BeH_sh zIGrH|K;$vqPJu4895Z+r!Zm8=v4}iv)sdi2TU*{4>R_mGf{r=${=As6Z~qteApY{x z_T@4N=CD9*N6X9Y^`{qJqgJbJ)f-#2J+5deqE9;KF|-(Y1|2xS8g4K=jFv4boFdX~ zGFH@H%sd7Yl_s%1g~o0i4i-5bbAq@}$DAPU(=jKA`*h3+;yxX7g1Aq|oFMMgF(-)o zbj%6jJ{@y{xKGF2Lz!_p<_2<~j=5pnr(f zw3}tP;!oCD8TJyFUgJu~XMFkkMn9WJ9maB?WHq=d`cPHZn-ueqB$e4|$XOz~pEwcd zhw~Ag2+$!B9txyF9o><7d%JW9a1pKNV}E&9B`7E~_r8l4--(!Sc&ZRB$L#zDu;4Wl zvz-rD-^Bzok8sULK+-2-ypM~$)$)#Q%e@(%;89SAbu1q@sN1ZE-cy^INAj>J*8~la zRPJLZ;}tNJDQPBJh0Vk8V=-Zp)s=hfON@5h=UuAVB5A42vlkQm$EdD%n75+ zll$Az-E-z>o2vg!)5vP{)<0|ZS{3co&1)FxZqo+MTKh0r6d|N7&+4vX`#|LSP zqBYw7v4|S1&RB0WXO|U!M;G{`D{L~9rUw|ZLw|Zb$e9lEKByD!qv{;|9j{K}V}F7S z5gXxG_{1~aE-O8pMk9Y3lY73*azFv4&}T-Q8*7U{AE1P2di{mJ9C2Fk^(GMrG3GHd z#EDB5SQ=+EYER0vp?-vRrB-M(5(Bm&15s@>2u~6s*nqr+A8O5NHp{PnwAzsVbHfp$ z1Ci_!qnrZs+!A*=`RgH55unc$_=Dn3#LRkou1x;V8k#sHP<0EY6<}7-pV0xUIIGQ~ zTXHSuaZ7=4IGINNiYoFx>@=i-v6YnxYRg~zG!7Q4D}%4hfl@6N9sw!lWOQLtQ!R-F z)wzVVQZOi@G0*~ol_cbtEY?I4b2UZx32bUf+hvLWOK8blk_cNWv2((bS%Fu2gn!XN zopwi$K=GW85v3S|!=YC$3$?bqU!hwD6)eM0mxtc40Wh-(WVC*wL$g=dW}{2gWaf1g zW}8Z&qn7IGkQc3vERf~QpITAJQyw`p; z?A8R!)%UcVJ(1IBs5zYkrlw`o6J%OOBf+I*B$a5jcbZS2K>z1O&&d zX7|{qjGJhSbX$di}s`tJsomJhriiT}T^;Q%o9rC2YrF@oU)@SA9k zJ!CTg?V8Bgsa!5>)l{MVCYdVS!)c(lxxq6k&A!QQ*^~&fvLw<_eKH0}S-xyGxaD7SPQf3ssR4>{1_OWPpyEO$cs#$Iegh>w< z@~20`=5goMY5TDMHxHDMa`Ir&r5>S8(^HgL<$pb`NRKCe5s#bpb4Z)g_9&i+w_dW~(bkG|+} zO%|tVcm|1wvWahc#bhB}r5?r;VQ6CW&S_2$GT@%@`w5wn!Z-w4GE8(lZU99PNg^Un z%1fx#QZf|atk}hv)LssNo!OS;Gg~b(3`(Rh^Y%3)wI-pM@-hL~1vU)sR!ltqb^M$Q@`Jwu01^U85^WTVe7S^9WTE>sI1lWr2pQ zyTsv-yeHej{tO7oBT~ta_$(&diF;?^zeVlNQ;Rz*tC4W(bj*Q-Xi{cG!QCFrcbEtb zq7FTjjjn->RClU>x~#ihjqNw;wMK2cpG-rJRUlk>wcC1ztFj;JV}P&M6!`kb#Ni8P zN`osYUJ_a!%cS+Vt2e3*q&!(B<9343rkjY_tZEFjMiqxAoYlpUuyX4GoH~gMt+bpW zxE*i)J9HrwCtkNK3sVBdJfmc}4)|<7NK6c)Qqim_l9nR^JRuNI74gHB$^+HvnOkx6 zPtFuqC<%?lX7B6>U6CCgot@ik?(i9nFuXtO_lE5wT;t@};1W_aox?}mLwx&y3^WFD zzq+zT1GE%VExWRtAaXzJH-$;}WVBN7YQ6i2Ga*1~0#1aKdnny$dfKJtVl7$C!pJyn z7rm|aQSI;d~T9D@QB&e3a=4rZWx_B*2y2T4J%LT~K~2NY3wt! zhQL6rEEHofX7ae0!I)@l-i}L@OUzE80kq@AjfZkua$iF;)v-u&5-hU0sApTe1YQ2- zOE%_G^u2TkWQ$fU`~0#L_{H{QViWZkeY=g9xTd0sx0QGJUSFR?NOTx1O78|`+Zu=_QgGZ2ThmidR%I= zZDN*LIz{V@jGe3vM*f_I7ad*UdpE;~0e3?zYN&rf4yVGo_b0%$t+a!mXOU`8Ex=@~jIPMC%)0X?+;ih0y3m_hi=WPW$!-^F(0 z6O$^64Xx$;ML^!mPL@~aw3XG)VYs2}zt0p_z$E)seWqrLEX|OP7?^D76o726afOXf zX-q5*IAth@sw1^^t9{z-|JZk1>z#DY`q@6}5L=?=0J%pvB~$x2l(ci)V+l4?%ZiZD zB4=+`|fqp;IjZdy}x1KpY|3bkso7!60lio?tb!et>e$=1?_Xe^rm zq6c13i5NAi-i;p~bsVy!mUab6|4;r*mmM8Tv84jXEgN@soIV$3nu= z(GywKMa&z34omT78v>XgLP|%d9K`K$ZZg!I&ZXM_MA#}(C|j?CcB)eaI|!hEfTBwW zw@foNk3mg;Rv|-#H4!c?pd_VLJ;{uSwsg$VnGiS0@zDb|p7bXT@qnullPdJ?e|wuP zL86%WOhfkfx>jWel*36R?YXqlya_Con?MRhRyura?AGvoBVG-2h$^EQB-FUbvmIJ8 zFLAX|QlFQ?iC~#%-%96?%rQbjL47Aqsg(mU{F&};tQX6=1Dm{;j?$P&j_}QHvXim1 zmbe7v*SJ(#TzJy8&m}&Fy)1_nSbn^JLM}e_E&bip9yHXj!1DE+p-+@Q0sI*?lxa}r zCocMRlmvwb&PrqI+V2J*6*+B3E3>Qpexm)}v*38DmD$&R|Dd<4WPAgZFz9O|a6@l(Lnm=VZ*jv$&-r^k_op;3C z{Ns8~7My8b_9S@SN%;*IP^V~M#gDsk@o7{^WS@5$(G&f#cZUk(#d_tHO+gKpD7G{d@b*gx~)^4TY^xu4wDCKg4(km!F!^wnEDq4BKE-s_>%Fuss za^oRU@`i{jWNE0izN(?!grL%W8_utSWw`p5qY+nQ38rnK^xz-Z+61%3YRKbsl$Cad zF&#YM4rd8XMFxZKm{w*MZsKqvc^)PcQZ@V-CT4Dljv(r$LoliuQ-KoC<2|Ppkz|407_GTyx9uZ zP0Uf&69)__LI8v7XHghZiKw2&2K6*}J;h;2O`>{sHmGNZ*HavZ7E?iO2vW`917Q~{L+WL)d8gw z>fUBi1-`l`WxT!~a%ajz@d^nWXnBalH(`eXd5C5W!&|I5zN{8ci^K_O>VX+GoyHFz zRoxmrs^R4;H8YavjE*fl7(n@46gvP}|5(Q>0qkEy+^m`|?s@DXjK*+>K9M;yU_QNp zpGG%93S8gw$Yrwdz5!!8Sl*=}h@k428Og8sU0d3#t>@lO<3L{EzUb+d;QM@U(q-A3 zv`5db$V*-2!F>RnKx4msO3RF>xrrV+{6ydD$%7~CgNl1UC1N`qIEkHtFn`(9FKV*4 z+Sq%gH2^Maj&=kuTBN}p+027ZlMkz)}SZY9mCV`nHhF@Lg3*I1RbKm&~=xI+!B zDPa{(L8Y$$(|AJG9%n5Ee!_I=6$g6y#<-v%_Lkea(>)H1f9&zCv>*znhUhx^F@m*@ z@odajqvaIo$)ta<6|VRpbnl;*mtqfI0c!jmvcRaSRU&J2;H_*nZ~Dm{?s?KCLiV^cNbak?!^ z5*W###Ni{#F1>9OOO%L2fF6>A;3-U!yJ)@iKvS5GfnAdcm0Z2jv>6Wlcs3lu-|GmL z-EbNVhh?hi+ZpIbe_w$}t9pN`{eAv-b{JXu_8)&=@oQ8vSz)Qq&{q(hfWq1!j1o%E zzFmInl^+u0GxCs8#1cKyFuMpzp|#IqE?fj~$Ma`oxI$)`E3P#y@pgq>v|tzo(3(lk z+(gSyoGLR4zTo52IZ&l%>F|9h;a z{|)9!aqw$Cv(2DV4vGHP@W4G7;GU!Z@8deQE26RFk93ENfP8gvTl$#C6vsm>sU3Wz zEw)RF!XiHesA2@y)a>7(At+_C*hnb>8O$Hhqn{2^*-WcEe-glZl^Q`R@8do(Jr)nzS#+vR z#7giG#>)Jp(M<~AK8+Njn;}3pfm&e^!68QZgUmjFa#=_qOJ}U^Lb*v4h=?@h{sjrgr4*o%BwTjD2 zX~4^%qboW=MQ$^Z1IVJTY3c4uUE7pyD2&f4hlL*{K9K9}$^IUN8KaQBqVZT}r$NR* z*Zy=J#N7T$@@3!I+22brtJ4**zu(_WH4BOZMdI>6DVKOm4g|ZrJz*CphW19r7T5cG z>0=Q^3}`Pg$;E51@Y9D-iN8xu{p)bKS_Ao!5E>U}@Ng1AOlg{`pptTmo`!xBenyP3 z5sHrV`bd8Fog&pRy78298s2Nep8Iw4^iXZOv8Z_Z5+bV%SjSH&tx@KXXNgoAE&~#V zv^1B0VoL6VKm50TP-oeyZU3-cdpt$qvV~_Yk7E=FtL>|=Q%9{{tL^RX{sGOcpYE~0 zb^aT^)pu)+Kh$ea_Ucb}cAo4up!}1)TI~;B?dw#Z{Q(8hUwYmjE`sUQUyd`%1d_wKAK`g1a89&Xl^b{nCk0Yv zRm7x;HD7iR136rVRoe%g7#b_)%NrWXg8nF6LF0)Qb4#xUuJ3n`;s4f~_JGY?7CGdB zrQDEocQM1s^uJD`wHJ)gef~JOSYKYUH=cNNdlLi;B-1?L9%p=vCrW4K=-r)Sals}Z zq}y5NtnJ-!7yozOI1HSX9d=I#z3%xSsjOaOceZq_IF5L$m(hBadVe(0yzF(GhplFR zAkZ{w5(!pIe;&`mI7VF{nuwNOEF*tB@?p<_F$et144NEwPG7Zq(s=DN{4YsG!Y8_T zr;b$if#A~+ccG#hCcEgmg0*8Mwu9anwgApLyWN+aQ>eI&6@tVP%P;UqfP@EH?X?Ig3PtsG4{bhFiJpAA~w(^CQc1M|7Xv;$fTCiqyHJ$djk#@%#^SFog>B9lQH%+L^&YDXQX z-C^r>yY+@zSg+fPob@{0UT5$lE7Gvap#EX2dveAIUEj6Ni?e3G-|Dpw8JefoBJFlB zEwcZBhvI-OWw^TYrolBRwB8nWY5_xb+B^0-XV-g>!a_CrBUHYpcPKmkIrp9D7}Iv^ z9Q!nEo)2EPPY0b=bI|FYddjC^?P~(sK5g}WJVUVIpw~R@lROciJ4HcH+kW?Cy1QFle@3505&>gG8cxjXnD+Z7cfJKC&=u zr_GbJSyXo4DjZ=p^ast8Go|PcY0-Y`#8yZKb+!S>s}A5!%`Mc9x;=@I812LCty4mN-8Lc0E z7Mdt&<^RRJ;o+-Z^8}|7ETTE`_7s-D3SY;i()~fNO~vCCw4WDd%8{jXulWv& zF8v!z)*)iydc)lo57ZuvgQvSKO{>$47>uR8Adsd;Z zC}X?18-XXeI=)q2E1H^haaD9Nt8i8X@{|F zcJ=e$r%xNdpa1?EANI0DoV>DOk1>goThZcI&{&Zi?tzva#yrFm-7C(=kMVU!1T*oD5aGL-`54W%F|b~+ zoW(%MG_bQkNOHjbi))!OItB;{2^O%kt7MK#F-Qfj8gdj)Qiau`zsB!q51NRFD zUJ#NB4SGMFQZ_^-9AnjsmV~A3b4yE5{Ai;AD~>m%;~NgU?IJe5Ku$cmi~N&8w^5m z0t@|XfN8$$9HXiNdv|)K!%v&Wp6{VQ-TW~mEIt`Uk@e4D)1UK{K1_eI?{K{z6M-b~|bsni5-p z`30q(zBYyk5*N`_$I82Gp-+4@vm^$#M4-+@!?1P`@-8OdijeX6vDRW(S5$y`0Gs__ z^*CJE(^n(PNCMW-qrfQUb`|VLl8NC(F&qnJ@*f(c447oam#fv?1$REoz6<{Q1(<}&y0_@z0cTpt{%d$-vp0kSa2E>*%8ZV=nE#qpu3@&XM zF^ZWHtbVpke7T~}50>+3%*IV5lfmHj)wd6jDL7r|d_aBbAz7(Zyq|y8)0@2$TQZBa z>@i;vX7t0z3s6ZWJ4*P`MwO5-YWU;YcSaG?f#hY4X(B!+t(&F6> zT1;Pe@$2q}jc1S^gH$`RaaXDg%|Xf0qbK+4Q5D-!^5{zA38p-$B<;IjPwDFukE8nX zE>{^UF_K2d_r6xgDRU3M?p3}P1sG0`;rv>(s4{#9Izi|$^Ibe#Q;X>*eKkwKLO;40 z*I5GlVJ$SKhr^;2{c@Mv+f_^M?V4rTTM)AJL-mYhXo>1tJRJJd#g#uC%1bUfxeook zT{RUFZ}<0xl&n@gge`Uud}2T7s~qfwmJ;6bRXBc-t|8$Zc0eq(!mlUNV3jq*xQ#F>mzl`o?6;AY4bCht-8Vm+xmNCm!t;G5rl{t&3GB**aIHq>X zV^bxcx>av7*4OPvRs6OP1xC2ls2pVB+S_$v0~W}^_k`i&15)*PF+xQTbgCZuw&7o= zksPyS8cilcYBB75Lky1IHtd76Dz&ns;-$ms>})a5Oa9BjMfWn%G)9!?j%VznCAIQeA8v~r00e4kVe_4kV9&oiLnVUjIeX%t=-xW zd&&bvBEJ8$)Bk4IJ>aP84uCaF7XvoLL4xwq7nCilD>jUuxmpk(?}HNWxYS!`erf#h~<;^ ziSz_dv=(~)y4xQN&zi5=EQV@1txj@8+nI0=Ha7^0XO3t(fd`CpIzOYBp!}HCy9vI- zbGv9BY;PwqOw?A3`pFfDeIO91Gqowr-`gO1*VUBg@^ru(`?GIfMMN0IOLZ6rZDtL z^K95W?VkROUyeHO+lTb+tk-$lMCUR!j8!B(!%HT-)H~+-ijRW9&#Akr`wXEWbtd#g z!+WH?XPS)TvdDt(8_-Ww$|A7vAA|x0+#KgIs$Aa)J?dru9T4cW-9Bs|vQY9Ohg?Ps zUv^%#PY*lI(~2SpMdK=I4RTmQ5~fw}BBgX%PJSJCbU6H5yVosaa{9_8^<#lQ8pV}-|@QwjHn(0eRyCy%?Qub}yZ{>O^<;)O{-sN$hl)(c~(lu8AiFV)RQNEhaV zBj`cDJt&8$A;rd%Ly2TWA%%mq0_fU8@Cny140fSaKzrhayy6`6f_$U!+E-x|@@c`W z2S84ZBj&I|rcPW-tAw3(<~PUzbC6KhA++#;^u}3@bgA*%jg{f9 z&FGj2_YdZ8r$+ry{EwfPEGVlMmUE7?!c`tbU1UcJ`X<%4Ht)e>dcqQYscI+~K598<5L?59|; znZTF6rG5Q3S>RA%S;7cGROT^SDpUd=#0YR?0gm=yqY1TKqn%>erj+42P<%CFFL}ha ziJ|o#vA>$1HKpog3bUVlDiG~>ba;d*D}|~`6O-5+N|~(}%k_|5qO7iA!jDouaTLhM zvd%@b&cYMtwI(jonmD&LaiP}C{M#j{cs2wq%Ly4e0mE##u@i2b2^Txz;w-os?0=^# zdk-lqgEs$gLQ<9!a*hC2K+19Van2rXTYJg!oUqZ_4a@V~J&iA8Q0c8brK~K-<>=Z4 z30WC5;xE(fWMY|a=<88@V+X|?H(clj3?<0*d?VpguUPii@&;C@xi~4W@!dWbg6t=V zzv~TztabNHio8|Crj_vD*E#YP8e?{k>b>52p-Zj=Mr5gF*BON+$>gTD(U_W(*4nBj zX#EwIHFaH+M(vlPxVD;E32#u`Ag)pPeiY~2El8fYXbPsmh^sbpr{b+pe+g>$qN=9d zu(TrJfdxEibmFCnY4%If>~HAbAlZrtwI6ebixqV4(M|d_;9pJcJkd`GpZIm7{7P%l z_yh?Gypm!Thi%D$kr#cE)PJIqtVTI&bkKdYqn#$y@J- ztYb4 zK_bgis07S8G8UZL!iZz^aAn&!YlyL%>3NW}fEd(3{ssd7#l_^_vt)&n@ZaR&Pv~|( z{6QZ6gu(^!%lmTs9g9r|L}No-SQBr#{I~aLQ?10Q2yTP~>z@YmA^L%x+ZCF$i6ViW z56kOh%n!;9sxl=4aHpbe7R*MAyE4m>;i()igul@Z&v4?;!s(q*X6k!o8A2*yYBpsR z_x<$9WW2r(wZC}Kf5q{tspF+mQy(wKs7T}XMdQUP`b@!W|MHi=cztFbPKMpERg65^ zbi=OmYU>4>8vMm`M6l4N;|M^+R77Z`8vZRjCMxL#3hAddMk7%KzW{YwC;eB$qfW0s zczxI_6TpFGOh+1K4$V*hR3vic99P0LEGTgr^NhlNd1XTP@S$9ryo@kMq~xfCxA?F* zXcCmPaIjJw1urZ&kYMB*F(b(L zyj%UVW~*IJxtf}Wc&OA1&S2OY^uN7~rqn2Py=7&$GBD!jGMKGlNx3Y4`x-r8(g5I# z`N=f8Q5|67=VBT7pX4Pv`Kl1;I+zLy?li07=pL0J?_(o(t3h_139eDzH=KX2>n7d8Y zTT#`k(}>RH9->L45&NMIr=h$GhJG}`V>R;4{HTJE2WF8((@RTARha;IjkKQeT?G*S zvCvYO(Tq|aAK1tq@);nz?lC6PWGvmJq#QuW6({S7fj@np$S+1#S>1PvEDj|Jtg5F9 z2&qcj+(YNVINiR=(xBhoNK1oTyl=Wt$cxPHOT%VMgC=vfJh#Np6!mh=c@ke;j;!+E zxd7zVgP&B04XBFyuLKTpFHPx;mB23V?Xa4tw64_YLM{_QED!%x>w~f~{P(U8@_Hcg z#czIn;A}{fQrYySC)tTJ7P8rd?`X2i#163mozX5<%zQmV-YZ)~0J!$2RY|}?inM1# zq*Nd|3KkzGmnn2xnaxwqJ0o<)gcD-WI(wFYpu>;W8GloZOWqV3@(Gf%RHGc{a}L5^4)d zb1Ekke#q#?T7}qTC)bkvOUTiYsKM#Rk;x)~ig(V2gKqzsnK(E$6M^?Sr!7kcIlJk> z%G2%*EV=F0+wR%GQcJHruxFgT8K4JcGvj1%K0NI7Tiv(qp1r1a&yhj>bC;fq)N@@0Sw=0cA${U&;k;Hs2o}1ifvmnZ3G5kn=>QmJ9 zY+U;eR66^ARsO|~wubWn1S;hyX2p6g#S_s_Xf;eU9LA!lPYlmCGw=gaq{}4;J(*{s z!{;IPROz8s#oSOmdr&HI)IcwhdH|_fZ#Ce=LzRIb$;n58POJ=gOw0!*?^XsZrRD=C zj<3w#i=2EUiEk_eNs^O~gt@*lFtFqTqd;!4%psuUeDK6&mVqJ3$w!iS)iRJIIr&J0 z-z@`&$jC<_{Bjv6M23Wdi&xnXmvfj!0dtr|j*QqMicKF~W)pcvfhi+=BAN3>

5X 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�^I_X>Hv&Uqh( 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 - - - - - - - - - - - - - - - - - - - - - - - diff --git a/qemu/qemu-git/gdb-xml/.svn/text-base/arm-neon.xml.svn-base b/qemu/qemu-git/gdb-xml/.svn/text-base/arm-neon.xml.svn-base deleted file mode 100644 index ce3ee03..0000000 --- a/qemu/qemu-git/gdb-xml/.svn/text-base/arm-neon.xml.svn-base +++ /dev/null @@ -1,88 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/qemu/qemu-git/gdb-xml/.svn/text-base/arm-vfp.xml.svn-base b/qemu/qemu-git/gdb-xml/.svn/text-base/arm-vfp.xml.svn-base deleted file mode 100644 index b20881e..0000000 --- a/qemu/qemu-git/gdb-xml/.svn/text-base/arm-vfp.xml.svn-base +++ /dev/null @@ -1,29 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/qemu/qemu-git/gdb-xml/.svn/text-base/arm-vfp3.xml.svn-base b/qemu/qemu-git/gdb-xml/.svn/text-base/arm-vfp3.xml.svn-base deleted file mode 100644 index 227afd8..0000000 --- a/qemu/qemu-git/gdb-xml/.svn/text-base/arm-vfp3.xml.svn-base +++ /dev/null @@ -1,45 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/qemu/qemu-git/target-arm/.svn/all-wcprops b/qemu/qemu-git/target-arm/.svn/all-wcprops deleted file mode 100644 index f762d52..0000000 --- a/qemu/qemu-git/target-arm/.svn/all-wcprops +++ /dev/null @@ -1,59 +0,0 @@ -K 25 -svn:wc:ra_dav:version-url -V 50 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/target-arm -END -neon_helper.c -K 25 -svn:wc:ra_dav:version-url -V 64 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/target-arm/neon_helper.c -END -helper.c -K 25 -svn:wc:ra_dav:version-url -V 59 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/target-arm/helper.c -END -iwmmxt_helper.c -K 25 -svn:wc:ra_dav:version-url -V 66 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/target-arm/iwmmxt_helper.c -END -op_addsub.h -K 25 -svn:wc:ra_dav:version-url -V 62 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/target-arm/op_addsub.h -END -helpers.h -K 25 -svn:wc:ra_dav:version-url -V 60 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/target-arm/helpers.h -END -exec.h -K 25 -svn:wc:ra_dav:version-url -V 57 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/target-arm/exec.h -END -cpu.h -K 25 -svn:wc:ra_dav:version-url -V 56 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/target-arm/cpu.h -END -op_helper.c -K 25 -svn:wc:ra_dav:version-url -V 62 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/target-arm/op_helper.c -END -translate.c -K 25 -svn:wc:ra_dav:version-url -V 62 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/target-arm/translate.c -END diff --git a/qemu/qemu-git/target-arm/.svn/entries b/qemu/qemu-git/target-arm/.svn/entries deleted file mode 100644 index f1e4908..0000000 --- a/qemu/qemu-git/target-arm/.svn/entries +++ /dev/null @@ -1,334 +0,0 @@ -10 - -dir -11 -http://svn.code.sf.net/p/x49gp/code/qemu/qemu-git/target-arm -http://svn.code.sf.net/p/x49gp/code - - - -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - -481df3bd-3408-496c-b7de-451e46197bb5 - -neon_helper.c -file - - - - -2013-08-23T00:54:48.000000Z -18af6516540342d43df7cc8892c5f4be -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -35208 - -helper.c -file - - - - -2013-08-23T00:54:48.000000Z -823155c4d333cf222454e866d2ce7d5f -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -73283 - -iwmmxt_helper.c -file - - - - -2013-08-23T00:54:48.000000Z -8250353c2a25355004e2a16e16a7790f -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -25270 - -op_addsub.h -file - - - - -2013-08-23T00:54:48.000000Z -b6b4efec5d913f6524d22b51e6c35b1e -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -1841 - -helpers.h -file - - - - -2013-08-23T00:54:48.000000Z -776a9380263a7c3b95531f8b96a2bcff -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -16327 - -exec.h -file - - - - -2013-08-23T00:54:48.000000Z -c2acd2fca23a0a1e0bbb05d36948c4ba -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -1603 - -cpu.h -file - - - - -2013-08-23T00:54:48.000000Z -354b69a5f0344806d9016a0e988a0a4d -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -14765 - -op_helper.c -file - - - - -2013-08-23T00:54:48.000000Z -c0efc1eb0fd92046061b3ce8fc79437f -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -10951 - -translate.c -file - - - - -2013-08-23T00:54:48.000000Z -cb17dd22f174b2437221c58d73ab9e53 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -317978 - diff --git a/qemu/qemu-git/target-arm/.svn/text-base/cpu.h.svn-base b/qemu/qemu-git/target-arm/.svn/text-base/cpu.h.svn-base deleted file mode 100644 index a75a5be..0000000 --- a/qemu/qemu-git/target-arm/.svn/text-base/cpu.h.svn-base +++ /dev/null @@ -1,457 +0,0 @@ -/* - * ARM virtual CPU header - * - * Copyright (c) 2003 Fabrice Bellard - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library 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 - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, see . - */ -#ifndef CPU_ARM_H -#define CPU_ARM_H - -#define TARGET_LONG_BITS 32 - -#define ELF_MACHINE EM_ARM - -#define CPUState struct CPUARMState - -#include "cpu-defs.h" - -#include "softfloat.h" - -#define TARGET_HAS_ICE 1 - -#define EXCP_UDEF 1 /* undefined instruction */ -#define EXCP_SWI 2 /* software interrupt */ -#define EXCP_PREFETCH_ABORT 3 -#define EXCP_DATA_ABORT 4 -#define EXCP_IRQ 5 -#define EXCP_FIQ 6 -#define EXCP_BKPT 7 -#define EXCP_EXCEPTION_EXIT 8 /* Return from v7M exception. */ -#define EXCP_KERNEL_TRAP 9 /* Jumped to kernel code page. */ -#define EXCP_STREX 10 - -#define ARMV7M_EXCP_RESET 1 -#define ARMV7M_EXCP_NMI 2 -#define ARMV7M_EXCP_HARD 3 -#define ARMV7M_EXCP_MEM 4 -#define ARMV7M_EXCP_BUS 5 -#define ARMV7M_EXCP_USAGE 6 -#define ARMV7M_EXCP_SVC 11 -#define ARMV7M_EXCP_DEBUG 12 -#define ARMV7M_EXCP_PENDSV 14 -#define ARMV7M_EXCP_SYSTICK 15 - -typedef void ARMWriteCPFunc(void *opaque, int cp_info, - int srcreg, int operand, uint32_t value); -typedef uint32_t ARMReadCPFunc(void *opaque, int cp_info, - int dstreg, int operand); - -struct arm_boot_info; - -#define NB_MMU_MODES 2 - -/* We currently assume float and double are IEEE single and double - precision respectively. - Doing runtime conversions is tricky because VFP registers may contain - integer values (eg. as the result of a FTOSI instruction). - s<2n> maps to the least significant half of d - s<2n+1> maps to the most significant half of d - */ - -typedef struct CPUARMState { - /* Regs for current mode. */ - uint32_t regs[16]; - /* Frequently accessed CPSR bits are stored separately for efficiently. - This contains all the other bits. Use cpsr_{read,write} to access - the whole CPSR. */ - uint32_t uncached_cpsr; - uint32_t spsr; - - /* Banked registers. */ - uint32_t banked_spsr[6]; - uint32_t banked_r13[6]; - uint32_t banked_r14[6]; - - /* These hold r8-r12. */ - uint32_t usr_regs[5]; - uint32_t fiq_regs[5]; - - /* cpsr flag cache for faster execution */ - uint32_t CF; /* 0 or 1 */ - uint32_t VF; /* V is the bit 31. All other bits are undefined */ - uint32_t NF; /* N is bit 31. All other bits are undefined. */ - uint32_t ZF; /* Z set if zero. */ - uint32_t QF; /* 0 or 1 */ - uint32_t GE; /* cpsr[19:16] */ - uint32_t thumb; /* cpsr[5]. 0 = arm mode, 1 = thumb mode. */ - uint32_t condexec_bits; /* IT bits. cpsr[15:10,26:25]. */ - - /* System control coprocessor (cp15) */ - struct { - uint32_t c0_cpuid; - uint32_t c0_cachetype; - uint32_t c0_ccsid[16]; /* Cache size. */ - uint32_t c0_clid; /* Cache level. */ - uint32_t c0_cssel; /* Cache size selection. */ - uint32_t c0_c1[8]; /* Feature registers. */ - uint32_t c0_c2[8]; /* Instruction set registers. */ - uint32_t c1_sys; /* System control register. */ - uint32_t c1_coproc; /* Coprocessor access register. */ - uint32_t c1_xscaleauxcr; /* XScale auxiliary control register. */ - uint32_t c2_base0; /* MMU translation table base 0. */ - uint32_t c2_base1; /* MMU translation table base 1. */ - uint32_t c2_control; /* MMU translation table base control. */ - uint32_t c2_mask; /* MMU translation table base selection mask. */ - uint32_t c2_base_mask; /* MMU translation table base 0 mask. */ - uint32_t c2_data; /* MPU data cachable bits. */ - uint32_t c2_insn; /* MPU instruction cachable bits. */ - uint32_t c3; /* MMU domain access control register - MPU write buffer control. */ - uint32_t c5_insn; /* Fault status registers. */ - uint32_t c5_data; - uint32_t c6_region[8]; /* MPU base/size registers. */ - uint32_t c6_insn; /* Fault address registers. */ - uint32_t c6_data; - uint32_t c9_insn; /* Cache lockdown registers. */ - uint32_t c9_data; - uint32_t c13_fcse; /* FCSE PID. */ - uint32_t c13_context; /* Context ID. */ - uint32_t c13_tls1; /* User RW Thread register. */ - uint32_t c13_tls2; /* User RO Thread register. */ - uint32_t c13_tls3; /* Privileged Thread register. */ - uint32_t c15_cpar; /* XScale Coprocessor Access Register */ - uint32_t c15_ticonfig; /* TI925T configuration byte. */ - uint32_t c15_i_max; /* Maximum D-cache dirty line index. */ - uint32_t c15_i_min; /* Minimum D-cache dirty line index. */ - uint32_t c15_threadid; /* TI debugger thread-ID. */ - } cp15; - - struct { - uint32_t other_sp; - uint32_t vecbase; - uint32_t basepri; - uint32_t control; - int current_sp; - int exception; - int pending_exception; - void *nvic; - } v7m; - - /* Coprocessor IO used by peripherals */ - struct { - ARMReadCPFunc *cp_read; - ARMWriteCPFunc *cp_write; - void *opaque; - } cp[15]; - - /* Thumb-2 EE state. */ - uint32_t teecr; - uint32_t teehbr; - - /* Internal CPU feature flags. */ - uint32_t features; - - /* Callback for vectored interrupt controller. */ - int (*get_irq_vector)(struct CPUARMState *); - void *irq_opaque; - - /* VFP coprocessor state. */ - struct { - float64 regs[32]; - - uint32_t xregs[16]; - /* We store these fpcsr fields separately for convenience. */ - int vec_len; - int vec_stride; - - /* scratch space when Tn are not sufficient. */ - uint32_t scratch[8]; - - float_status fp_status; - } vfp; - uint32_t exclusive_addr; - uint32_t exclusive_val; - uint32_t exclusive_high; -#if defined(CONFIG_USER_ONLY) - uint32_t exclusive_test; - uint32_t exclusive_info; -#endif - - /* iwMMXt coprocessor state. */ - struct { - uint64_t regs[16]; - uint64_t val; - - uint32_t cregs[16]; - } iwmmxt; - -#if defined(CONFIG_USER_ONLY) - /* For usermode syscall translation. */ - int eabi; -#endif - - CPU_COMMON - - /* These fields after the common ones so they are preserved on reset. */ - struct arm_boot_info *boot_info; -} CPUARMState; - -CPUARMState *cpu_arm_init(const char *cpu_model); -void arm_translate_init(void); -int cpu_arm_exec(CPUARMState *s); -void cpu_arm_close(CPUARMState *s); -void do_interrupt(CPUARMState *); -void switch_mode(CPUARMState *, int); -uint32_t do_arm_semihosting(CPUARMState *env); - -/* you can call this signal handler from your SIGBUS and SIGSEGV - signal handlers to inform the virtual CPU of exceptions. non zero - is returned if the signal was handled by the virtual CPU. */ -int cpu_arm_signal_handler(int host_signum, void *pinfo, - void *puc); -int cpu_arm_handle_mmu_fault (CPUARMState *env, target_ulong address, int rw, - int mmu_idx, int is_softmuu); -#define cpu_handle_mmu_fault cpu_arm_handle_mmu_fault - -void cpu_lock(void); -void cpu_unlock(void); -static inline void cpu_set_tls(CPUARMState *env, target_ulong newtls) -{ - env->cp15.c13_tls2 = newtls; -} - -#define CPSR_M (0x1f) -#define CPSR_T (1 << 5) -#define CPSR_F (1 << 6) -#define CPSR_I (1 << 7) -#define CPSR_A (1 << 8) -#define CPSR_E (1 << 9) -#define CPSR_IT_2_7 (0xfc00) -#define CPSR_GE (0xf << 16) -#define CPSR_RESERVED (0xf << 20) -#define CPSR_J (1 << 24) -#define CPSR_IT_0_1 (3 << 25) -#define CPSR_Q (1 << 27) -#define CPSR_V (1 << 28) -#define CPSR_C (1 << 29) -#define CPSR_Z (1 << 30) -#define CPSR_N (1 << 31) -#define CPSR_NZCV (CPSR_N | CPSR_Z | CPSR_C | CPSR_V) - -#define CPSR_IT (CPSR_IT_0_1 | CPSR_IT_2_7) -#define CACHED_CPSR_BITS (CPSR_T | CPSR_GE | CPSR_IT | CPSR_Q | CPSR_NZCV) -/* Bits writable in user mode. */ -#define CPSR_USER (CPSR_NZCV | CPSR_Q | CPSR_GE) -/* Execution state bits. MRS read as zero, MSR writes ignored. */ -#define CPSR_EXEC (CPSR_T | CPSR_IT | CPSR_J) - -/* Return the current CPSR value. */ -uint32_t cpsr_read(CPUARMState *env); -/* Set the CPSR. Note that some bits of mask must be all-set or all-clear. */ -void cpsr_write(CPUARMState *env, uint32_t val, uint32_t mask); - -/* Return the current xPSR value. */ -static inline uint32_t xpsr_read(CPUARMState *env) -{ - int ZF; - ZF = (env->ZF == 0); - return (env->NF & 0x80000000) | (ZF << 30) - | (env->CF << 29) | ((env->VF & 0x80000000) >> 3) | (env->QF << 27) - | (env->thumb << 24) | ((env->condexec_bits & 3) << 25) - | ((env->condexec_bits & 0xfc) << 8) - | env->v7m.exception; -} - -/* Set the xPSR. Note that some bits of mask must be all-set or all-clear. */ -static inline void xpsr_write(CPUARMState *env, uint32_t val, uint32_t mask) -{ - if (mask & CPSR_NZCV) { - env->ZF = (~val) & CPSR_Z; - env->NF = val; - env->CF = (val >> 29) & 1; - env->VF = (val << 3) & 0x80000000; - } - if (mask & CPSR_Q) - env->QF = ((val & CPSR_Q) != 0); - if (mask & (1 << 24)) - env->thumb = ((val & (1 << 24)) != 0); - if (mask & CPSR_IT_0_1) { - env->condexec_bits &= ~3; - env->condexec_bits |= (val >> 25) & 3; - } - if (mask & CPSR_IT_2_7) { - env->condexec_bits &= 3; - env->condexec_bits |= (val >> 8) & 0xfc; - } - if (mask & 0x1ff) { - env->v7m.exception = val & 0x1ff; - } -} - -enum arm_cpu_mode { - ARM_CPU_MODE_USR = 0x10, - ARM_CPU_MODE_FIQ = 0x11, - ARM_CPU_MODE_IRQ = 0x12, - ARM_CPU_MODE_SVC = 0x13, - ARM_CPU_MODE_ABT = 0x17, - ARM_CPU_MODE_UND = 0x1b, - ARM_CPU_MODE_SYS = 0x1f -}; - -/* VFP system registers. */ -#define ARM_VFP_FPSID 0 -#define ARM_VFP_FPSCR 1 -#define ARM_VFP_MVFR1 6 -#define ARM_VFP_MVFR0 7 -#define ARM_VFP_FPEXC 8 -#define ARM_VFP_FPINST 9 -#define ARM_VFP_FPINST2 10 - -/* iwMMXt coprocessor control registers. */ -#define ARM_IWMMXT_wCID 0 -#define ARM_IWMMXT_wCon 1 -#define ARM_IWMMXT_wCSSF 2 -#define ARM_IWMMXT_wCASF 3 -#define ARM_IWMMXT_wCGR0 8 -#define ARM_IWMMXT_wCGR1 9 -#define ARM_IWMMXT_wCGR2 10 -#define ARM_IWMMXT_wCGR3 11 - -enum arm_features { - ARM_FEATURE_VFP, - ARM_FEATURE_AUXCR, /* ARM1026 Auxiliary control register. */ - ARM_FEATURE_XSCALE, /* Intel XScale extensions. */ - ARM_FEATURE_IWMMXT, /* Intel iwMMXt extension. */ - ARM_FEATURE_V6, - ARM_FEATURE_V6K, - ARM_FEATURE_V7, - ARM_FEATURE_THUMB2, - ARM_FEATURE_MPU, /* Only has Memory Protection Unit, not full MMU. */ - ARM_FEATURE_VFP3, - ARM_FEATURE_VFP_FP16, - ARM_FEATURE_NEON, - ARM_FEATURE_DIV, - ARM_FEATURE_M, /* Microcontroller profile. */ - ARM_FEATURE_OMAPCP, /* OMAP specific CP15 ops handling. */ - ARM_FEATURE_THUMB2EE -}; - -static inline int arm_feature(CPUARMState *env, int feature) -{ - return (env->features & (1u << feature)) != 0; -} - -void arm_cpu_list(FILE *f, int (*cpu_fprintf)(FILE *f, const char *fmt, ...)); - -/* Interface between CPU and Interrupt controller. */ -void armv7m_nvic_set_pending(void *opaque, int irq); -int armv7m_nvic_acknowledge_irq(void *opaque); -void armv7m_nvic_complete_irq(void *opaque, int irq); - -void cpu_arm_set_cp_io(CPUARMState *env, int cpnum, - ARMReadCPFunc *cp_read, ARMWriteCPFunc *cp_write, - void *opaque); - -/* Does the core conform to the the "MicroController" profile. e.g. Cortex-M3. - Note the M in older cores (eg. ARM7TDMI) stands for Multiply. These are - conventional cores (ie. Application or Realtime profile). */ - -#define IS_M(env) arm_feature(env, ARM_FEATURE_M) -#define ARM_CPUID(env) (env->cp15.c0_cpuid) - -#define ARM_CPUID_ARM1026 0x4106a262 -#define ARM_CPUID_ARM926 0x41069265 -#define ARM_CPUID_ARM946 0x41059461 -#define ARM_CPUID_TI915T 0x54029152 -#define ARM_CPUID_TI925T 0x54029252 -#define ARM_CPUID_PXA250 0x69052100 -#define ARM_CPUID_PXA255 0x69052d00 -#define ARM_CPUID_PXA260 0x69052903 -#define ARM_CPUID_PXA261 0x69052d05 -#define ARM_CPUID_PXA262 0x69052d06 -#define ARM_CPUID_PXA270 0x69054110 -#define ARM_CPUID_PXA270_A0 0x69054110 -#define ARM_CPUID_PXA270_A1 0x69054111 -#define ARM_CPUID_PXA270_B0 0x69054112 -#define ARM_CPUID_PXA270_B1 0x69054113 -#define ARM_CPUID_PXA270_C0 0x69054114 -#define ARM_CPUID_PXA270_C5 0x69054117 -#define ARM_CPUID_ARM1136 0x4117b363 -#define ARM_CPUID_ARM1136_R2 0x4107b362 -#define ARM_CPUID_ARM11MPCORE 0x410fb022 -#define ARM_CPUID_CORTEXA8 0x410fc080 -#define ARM_CPUID_CORTEXA9 0x410fc090 -#define ARM_CPUID_CORTEXM3 0x410fc231 -#define ARM_CPUID_ANY 0xffffffff - -#if defined(CONFIG_USER_ONLY) -#define TARGET_PAGE_BITS 12 -#else -/* The ARM MMU allows 1k pages. */ -/* ??? Linux doesn't actually use these, and they're deprecated in recent - architecture revisions. Maybe a configure option to disable them. */ -#define TARGET_PAGE_BITS 10 -#endif - -#define cpu_init cpu_arm_init -#define cpu_exec cpu_arm_exec -#define cpu_gen_code cpu_arm_gen_code -#define cpu_signal_handler cpu_arm_signal_handler -#define cpu_list arm_cpu_list - -#ifndef X49GP -#define CPU_SAVE_VERSION 2 -#endif - -/* MMU modes definitions */ -#define MMU_MODE0_SUFFIX _kernel -#define MMU_MODE1_SUFFIX _user -#define MMU_USER_IDX 1 -static inline int cpu_mmu_index (CPUState *env) -{ - return (env->uncached_cpsr & CPSR_M) == ARM_CPU_MODE_USR ? 1 : 0; -} - -#if defined(CONFIG_USER_ONLY) -static inline void cpu_clone_regs(CPUState *env, target_ulong newsp) -{ - if (newsp) - env->regs[13] = newsp; - env->regs[0] = 0; -} -#endif - -#include "cpu-all.h" -#include "exec-all.h" - -static inline void cpu_pc_from_tb(CPUState *env, TranslationBlock *tb) -{ - env->regs[15] = tb->pc; -} - -static inline void cpu_get_tb_cpu_state(CPUState *env, target_ulong *pc, - target_ulong *cs_base, int *flags) -{ - *pc = env->regs[15]; - *cs_base = 0; - *flags = env->thumb | (env->vfp.vec_len << 1) - | (env->vfp.vec_stride << 4) | (env->condexec_bits << 8); - if ((env->uncached_cpsr & CPSR_M) != ARM_CPU_MODE_USR) - *flags |= (1 << 6); - if (env->vfp.xregs[ARM_VFP_FPEXC] & (1 << 30)) - *flags |= (1 << 7); -} - -#endif diff --git a/qemu/qemu-git/target-arm/.svn/text-base/exec.h.svn-base b/qemu/qemu-git/target-arm/.svn/text-base/exec.h.svn-base deleted file mode 100644 index e9848e1..0000000 --- a/qemu/qemu-git/target-arm/.svn/text-base/exec.h.svn-base +++ /dev/null @@ -1,60 +0,0 @@ -/* - * ARM execution defines - * - * Copyright (c) 2003 Fabrice Bellard - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library 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 - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, see . - */ -#include "config.h" -#include "dyngen-exec.h" - -register struct CPUARMState *env asm(AREG0); - -#define M0 env->iwmmxt.val - -#include "cpu.h" -#include "exec-all.h" - -static inline void env_to_regs(void) -{ -} - -static inline void regs_to_env(void) -{ -} - -static inline int cpu_has_work(CPUState *env) -{ - return (env->interrupt_request & - (CPU_INTERRUPT_FIQ | CPU_INTERRUPT_HARD | CPU_INTERRUPT_EXITTB)); -} - -static inline int cpu_halted(CPUState *env) { - if (!env->halted) - return 0; - /* An interrupt wakes the CPU even if the I and F CPSR bits are - set. We use EXITTB to silently wake CPU without causing an - actual interrupt. */ - if (cpu_has_work(env)) { - env->halted = 0; - return 0; - } - return EXCP_HALTED; -} - -#if !defined(CONFIG_USER_ONLY) -#include "softmmu_exec.h" -#endif - -void raise_exception(int); diff --git a/qemu/qemu-git/target-arm/.svn/text-base/helper.c.svn-base b/qemu/qemu-git/target-arm/.svn/text-base/helper.c.svn-base deleted file mode 100644 index b3aec99..0000000 --- a/qemu/qemu-git/target-arm/.svn/text-base/helper.c.svn-base +++ /dev/null @@ -1,2598 +0,0 @@ -#include -#include -#include - -#include "cpu.h" -#include "exec-all.h" -#include "gdbstub.h" -#include "helpers.h" -#include "qemu-common.h" -#include "host-utils.h" - -static uint32_t cortexa9_cp15_c0_c1[8] = -{ 0x1031, 0x11, 0x000, 0, 0x00100103, 0x20000000, 0x01230000, 0x00002111 }; - -static uint32_t cortexa9_cp15_c0_c2[8] = -{ 0x00101111, 0x13112111, 0x21232041, 0x11112131, 0x00111142, 0, 0, 0 }; - -static uint32_t cortexa8_cp15_c0_c1[8] = -{ 0x1031, 0x11, 0x400, 0, 0x31100003, 0x20000000, 0x01202000, 0x11 }; - -static uint32_t cortexa8_cp15_c0_c2[8] = -{ 0x00101111, 0x12112111, 0x21232031, 0x11112131, 0x00111142, 0, 0, 0 }; - -static uint32_t mpcore_cp15_c0_c1[8] = -{ 0x111, 0x1, 0, 0x2, 0x01100103, 0x10020302, 0x01222000, 0 }; - -static uint32_t mpcore_cp15_c0_c2[8] = -{ 0x00100011, 0x12002111, 0x11221011, 0x01102131, 0x141, 0, 0, 0 }; - -static uint32_t arm1136_cp15_c0_c1[8] = -{ 0x111, 0x1, 0x2, 0x3, 0x01130003, 0x10030302, 0x01222110, 0 }; - -static uint32_t arm1136_cp15_c0_c2[8] = -{ 0x00140011, 0x12002111, 0x11231111, 0x01102131, 0x141, 0, 0, 0 }; - -static uint32_t cpu_arm_find_by_name(const char *name); - -static inline void set_feature(CPUARMState *env, int feature) -{ - env->features |= 1u << feature; -} - -static void cpu_reset_model_id(CPUARMState *env, uint32_t id) -{ - env->cp15.c0_cpuid = id; - switch (id) { - case ARM_CPUID_ARM926: - set_feature(env, ARM_FEATURE_VFP); - env->vfp.xregs[ARM_VFP_FPSID] = 0x41011090; - env->cp15.c0_cachetype = 0x1dd20d2; - env->cp15.c1_sys = 0x00090078; - break; - case ARM_CPUID_ARM946: - set_feature(env, ARM_FEATURE_MPU); - env->cp15.c0_cachetype = 0x0f004006; - env->cp15.c1_sys = 0x00000078; - break; - case ARM_CPUID_ARM1026: - set_feature(env, ARM_FEATURE_VFP); - set_feature(env, ARM_FEATURE_AUXCR); - env->vfp.xregs[ARM_VFP_FPSID] = 0x410110a0; - env->cp15.c0_cachetype = 0x1dd20d2; - env->cp15.c1_sys = 0x00090078; - break; - case ARM_CPUID_ARM1136_R2: - case ARM_CPUID_ARM1136: - set_feature(env, ARM_FEATURE_V6); - set_feature(env, ARM_FEATURE_VFP); - set_feature(env, ARM_FEATURE_AUXCR); - env->vfp.xregs[ARM_VFP_FPSID] = 0x410120b4; - env->vfp.xregs[ARM_VFP_MVFR0] = 0x11111111; - env->vfp.xregs[ARM_VFP_MVFR1] = 0x00000000; - memcpy(env->cp15.c0_c1, arm1136_cp15_c0_c1, 8 * sizeof(uint32_t)); - memcpy(env->cp15.c0_c2, arm1136_cp15_c0_c2, 8 * sizeof(uint32_t)); - env->cp15.c0_cachetype = 0x1dd20d2; - break; - case ARM_CPUID_ARM11MPCORE: - set_feature(env, ARM_FEATURE_V6); - set_feature(env, ARM_FEATURE_V6K); - set_feature(env, ARM_FEATURE_VFP); - set_feature(env, ARM_FEATURE_AUXCR); - env->vfp.xregs[ARM_VFP_FPSID] = 0x410120b4; - env->vfp.xregs[ARM_VFP_MVFR0] = 0x11111111; - env->vfp.xregs[ARM_VFP_MVFR1] = 0x00000000; - memcpy(env->cp15.c0_c1, mpcore_cp15_c0_c1, 8 * sizeof(uint32_t)); - memcpy(env->cp15.c0_c2, mpcore_cp15_c0_c2, 8 * sizeof(uint32_t)); - env->cp15.c0_cachetype = 0x1dd20d2; - break; - case ARM_CPUID_CORTEXA8: - set_feature(env, ARM_FEATURE_V6); - set_feature(env, ARM_FEATURE_V6K); - set_feature(env, ARM_FEATURE_V7); - set_feature(env, ARM_FEATURE_AUXCR); - set_feature(env, ARM_FEATURE_THUMB2); - set_feature(env, ARM_FEATURE_VFP); - set_feature(env, ARM_FEATURE_VFP3); - set_feature(env, ARM_FEATURE_NEON); - set_feature(env, ARM_FEATURE_THUMB2EE); - env->vfp.xregs[ARM_VFP_FPSID] = 0x410330c0; - env->vfp.xregs[ARM_VFP_MVFR0] = 0x11110222; - env->vfp.xregs[ARM_VFP_MVFR1] = 0x00011100; - memcpy(env->cp15.c0_c1, cortexa8_cp15_c0_c1, 8 * sizeof(uint32_t)); - memcpy(env->cp15.c0_c2, cortexa8_cp15_c0_c2, 8 * sizeof(uint32_t)); - env->cp15.c0_cachetype = 0x82048004; - env->cp15.c0_clid = (1 << 27) | (2 << 24) | 3; - env->cp15.c0_ccsid[0] = 0xe007e01a; /* 16k L1 dcache. */ - env->cp15.c0_ccsid[1] = 0x2007e01a; /* 16k L1 icache. */ - env->cp15.c0_ccsid[2] = 0xf0000000; /* No L2 icache. */ - break; - case ARM_CPUID_CORTEXA9: - set_feature(env, ARM_FEATURE_V6); - set_feature(env, ARM_FEATURE_V6K); - set_feature(env, ARM_FEATURE_V7); - set_feature(env, ARM_FEATURE_AUXCR); - set_feature(env, ARM_FEATURE_THUMB2); - set_feature(env, ARM_FEATURE_VFP); - set_feature(env, ARM_FEATURE_VFP3); - set_feature(env, ARM_FEATURE_VFP_FP16); - set_feature(env, ARM_FEATURE_NEON); - set_feature(env, ARM_FEATURE_THUMB2EE); - env->vfp.xregs[ARM_VFP_FPSID] = 0x41034000; /* Guess */ - env->vfp.xregs[ARM_VFP_MVFR0] = 0x11110222; - env->vfp.xregs[ARM_VFP_MVFR1] = 0x01111111; - memcpy(env->cp15.c0_c1, cortexa9_cp15_c0_c1, 8 * sizeof(uint32_t)); - memcpy(env->cp15.c0_c2, cortexa9_cp15_c0_c2, 8 * sizeof(uint32_t)); - env->cp15.c0_cachetype = 0x80038003; - env->cp15.c0_clid = (1 << 27) | (1 << 24) | 3; - env->cp15.c0_ccsid[0] = 0xe00fe015; /* 16k L1 dcache. */ - env->cp15.c0_ccsid[1] = 0x200fe015; /* 16k L1 icache. */ - break; - case ARM_CPUID_CORTEXM3: - set_feature(env, ARM_FEATURE_V6); - set_feature(env, ARM_FEATURE_THUMB2); - set_feature(env, ARM_FEATURE_V7); - set_feature(env, ARM_FEATURE_M); - set_feature(env, ARM_FEATURE_DIV); - break; - case ARM_CPUID_ANY: /* For userspace emulation. */ - set_feature(env, ARM_FEATURE_V6); - set_feature(env, ARM_FEATURE_V6K); - set_feature(env, ARM_FEATURE_V7); - set_feature(env, ARM_FEATURE_THUMB2); - set_feature(env, ARM_FEATURE_VFP); - set_feature(env, ARM_FEATURE_VFP3); - set_feature(env, ARM_FEATURE_VFP_FP16); - set_feature(env, ARM_FEATURE_NEON); - set_feature(env, ARM_FEATURE_THUMB2EE); - set_feature(env, ARM_FEATURE_DIV); - break; - case ARM_CPUID_TI915T: - case ARM_CPUID_TI925T: - set_feature(env, ARM_FEATURE_OMAPCP); - env->cp15.c0_cpuid = ARM_CPUID_TI925T; /* Depends on wiring. */ - env->cp15.c0_cachetype = 0x5109149; - env->cp15.c1_sys = 0x00000070; - env->cp15.c15_i_max = 0x000; - env->cp15.c15_i_min = 0xff0; - break; - case ARM_CPUID_PXA250: - case ARM_CPUID_PXA255: - case ARM_CPUID_PXA260: - case ARM_CPUID_PXA261: - case ARM_CPUID_PXA262: - set_feature(env, ARM_FEATURE_XSCALE); - /* JTAG_ID is ((id << 28) | 0x09265013) */ - env->cp15.c0_cachetype = 0xd172172; - env->cp15.c1_sys = 0x00000078; - break; - case ARM_CPUID_PXA270_A0: - case ARM_CPUID_PXA270_A1: - case ARM_CPUID_PXA270_B0: - case ARM_CPUID_PXA270_B1: - case ARM_CPUID_PXA270_C0: - case ARM_CPUID_PXA270_C5: - set_feature(env, ARM_FEATURE_XSCALE); - /* JTAG_ID is ((id << 28) | 0x09265013) */ - set_feature(env, ARM_FEATURE_IWMMXT); - env->iwmmxt.cregs[ARM_IWMMXT_wCID] = 0x69051000 | 'Q'; - env->cp15.c0_cachetype = 0xd172172; - env->cp15.c1_sys = 0x00000078; - break; - default: - cpu_abort(env, "Bad CPU ID: %x\n", id); - break; - } -} - -void cpu_reset(CPUARMState *env) -{ - uint32_t id; - - if (qemu_loglevel_mask(CPU_LOG_RESET)) { - qemu_log("CPU Reset (CPU %d)\n", env->cpu_index); - log_cpu_state(env, 0); - } - - id = env->cp15.c0_cpuid; - memset(env, 0, offsetof(CPUARMState, breakpoints)); - if (id) - cpu_reset_model_id(env, id); -#if defined (CONFIG_USER_ONLY) - env->uncached_cpsr = ARM_CPU_MODE_USR; - env->vfp.xregs[ARM_VFP_FPEXC] = 1 << 30; -#else - /* SVC mode with interrupts disabled. */ - env->uncached_cpsr = ARM_CPU_MODE_SVC | CPSR_A | CPSR_F | CPSR_I; - /* On ARMv7-M the CPSR_I is the value of the PRIMASK register, and is - clear at reset. */ - if (IS_M(env)) - env->uncached_cpsr &= ~CPSR_I; - env->vfp.xregs[ARM_VFP_FPEXC] = 0; - env->cp15.c2_base_mask = 0xffffc000u; -#endif - env->regs[15] = 0; - tlb_flush(env, 1); -} - -static int vfp_gdb_get_reg(CPUState *env, uint8_t *buf, int reg) -{ - int nregs; - - /* VFP data registers are always little-endian. */ - nregs = arm_feature(env, ARM_FEATURE_VFP3) ? 32 : 16; - if (reg < nregs) { - stfq_le_p(buf, env->vfp.regs[reg]); - return 8; - } - if (arm_feature(env, ARM_FEATURE_NEON)) { - /* Aliases for Q regs. */ - nregs += 16; - if (reg < nregs) { - stfq_le_p(buf, env->vfp.regs[(reg - 32) * 2]); - stfq_le_p(buf + 8, env->vfp.regs[(reg - 32) * 2 + 1]); - return 16; - } - } - switch (reg - nregs) { - case 0: stl_p(buf, env->vfp.xregs[ARM_VFP_FPSID]); return 4; - case 1: stl_p(buf, env->vfp.xregs[ARM_VFP_FPSCR]); return 4; - case 2: stl_p(buf, env->vfp.xregs[ARM_VFP_FPEXC]); return 4; - } - return 0; -} - -static int vfp_gdb_set_reg(CPUState *env, uint8_t *buf, int reg) -{ - int nregs; - - nregs = arm_feature(env, ARM_FEATURE_VFP3) ? 32 : 16; - if (reg < nregs) { - env->vfp.regs[reg] = ldfq_le_p(buf); - return 8; - } - if (arm_feature(env, ARM_FEATURE_NEON)) { - nregs += 16; - if (reg < nregs) { - env->vfp.regs[(reg - 32) * 2] = ldfq_le_p(buf); - env->vfp.regs[(reg - 32) * 2 + 1] = ldfq_le_p(buf + 8); - return 16; - } - } - switch (reg - nregs) { - case 0: env->vfp.xregs[ARM_VFP_FPSID] = ldl_p(buf); return 4; - case 1: env->vfp.xregs[ARM_VFP_FPSCR] = ldl_p(buf); return 4; - case 2: env->vfp.xregs[ARM_VFP_FPEXC] = ldl_p(buf) & (1 << 30); return 4; - } - return 0; -} - -CPUARMState *cpu_arm_init(const char *cpu_model) -{ - CPUARMState *env; - uint32_t id; - static int inited = 0; - - id = cpu_arm_find_by_name(cpu_model); - if (id == 0) - return NULL; - env = qemu_mallocz(sizeof(CPUARMState)); - cpu_exec_init(env); - if (!inited) { - inited = 1; - arm_translate_init(); - } - - env->cpu_model_str = cpu_model; - env->cp15.c0_cpuid = id; - cpu_reset(env); - if (arm_feature(env, ARM_FEATURE_NEON)) { - gdb_register_coprocessor(env, vfp_gdb_get_reg, vfp_gdb_set_reg, - 51, "arm-neon.xml", 0); - } else if (arm_feature(env, ARM_FEATURE_VFP3)) { - gdb_register_coprocessor(env, vfp_gdb_get_reg, vfp_gdb_set_reg, - 35, "arm-vfp3.xml", 0); - } else if (arm_feature(env, ARM_FEATURE_VFP)) { - gdb_register_coprocessor(env, vfp_gdb_get_reg, vfp_gdb_set_reg, - 19, "arm-vfp.xml", 0); - } - qemu_init_vcpu(env); - return env; -} - -struct arm_cpu_t { - uint32_t id; - const char *name; -}; - -static const struct arm_cpu_t arm_cpu_names[] = { - { ARM_CPUID_ARM926, "arm926"}, - { ARM_CPUID_ARM946, "arm946"}, - { ARM_CPUID_ARM1026, "arm1026"}, - { ARM_CPUID_ARM1136, "arm1136"}, - { ARM_CPUID_ARM1136_R2, "arm1136-r2"}, - { ARM_CPUID_ARM11MPCORE, "arm11mpcore"}, - { ARM_CPUID_CORTEXM3, "cortex-m3"}, - { ARM_CPUID_CORTEXA8, "cortex-a8"}, - { ARM_CPUID_CORTEXA9, "cortex-a9"}, - { ARM_CPUID_TI925T, "ti925t" }, - { ARM_CPUID_PXA250, "pxa250" }, - { ARM_CPUID_PXA255, "pxa255" }, - { ARM_CPUID_PXA260, "pxa260" }, - { ARM_CPUID_PXA261, "pxa261" }, - { ARM_CPUID_PXA262, "pxa262" }, - { ARM_CPUID_PXA270, "pxa270" }, - { ARM_CPUID_PXA270_A0, "pxa270-a0" }, - { ARM_CPUID_PXA270_A1, "pxa270-a1" }, - { ARM_CPUID_PXA270_B0, "pxa270-b0" }, - { ARM_CPUID_PXA270_B1, "pxa270-b1" }, - { ARM_CPUID_PXA270_C0, "pxa270-c0" }, - { ARM_CPUID_PXA270_C5, "pxa270-c5" }, - { ARM_CPUID_ANY, "any"}, - { 0, NULL} -}; - -void arm_cpu_list(FILE *f, int (*cpu_fprintf)(FILE *f, const char *fmt, ...)) -{ - int i; - - (*cpu_fprintf)(f, "Available CPUs:\n"); - for (i = 0; arm_cpu_names[i].name; i++) { - (*cpu_fprintf)(f, " %s\n", arm_cpu_names[i].name); - } -} - -/* return 0 if not found */ -static uint32_t cpu_arm_find_by_name(const char *name) -{ - int i; - uint32_t id; - - id = 0; - for (i = 0; arm_cpu_names[i].name; i++) { - if (strcmp(name, arm_cpu_names[i].name) == 0) { - id = arm_cpu_names[i].id; - break; - } - } - return id; -} - -void cpu_arm_close(CPUARMState *env) -{ - free(env); -} - -uint32_t cpsr_read(CPUARMState *env) -{ - int ZF; - ZF = (env->ZF == 0); - return env->uncached_cpsr | (env->NF & 0x80000000) | (ZF << 30) | - (env->CF << 29) | ((env->VF & 0x80000000) >> 3) | (env->QF << 27) - | (env->thumb << 5) | ((env->condexec_bits & 3) << 25) - | ((env->condexec_bits & 0xfc) << 8) - | (env->GE << 16); -} - -void cpsr_write(CPUARMState *env, uint32_t val, uint32_t mask) -{ - if (mask & CPSR_NZCV) { - env->ZF = (~val) & CPSR_Z; - env->NF = val; - env->CF = (val >> 29) & 1; - env->VF = (val << 3) & 0x80000000; - } - if (mask & CPSR_Q) - env->QF = ((val & CPSR_Q) != 0); - if (mask & CPSR_T) - env->thumb = ((val & CPSR_T) != 0); - if (mask & CPSR_IT_0_1) { - env->condexec_bits &= ~3; - env->condexec_bits |= (val >> 25) & 3; - } - if (mask & CPSR_IT_2_7) { - env->condexec_bits &= 3; - env->condexec_bits |= (val >> 8) & 0xfc; - } - if (mask & CPSR_GE) { - env->GE = (val >> 16) & 0xf; - } - - if ((env->uncached_cpsr ^ val) & mask & CPSR_M) { - switch_mode(env, val & CPSR_M); - } - mask &= ~CACHED_CPSR_BITS; - env->uncached_cpsr = (env->uncached_cpsr & ~mask) | (val & mask); -} - -/* Sign/zero extend */ -uint32_t HELPER(sxtb16)(uint32_t x) -{ - uint32_t res; - res = (uint16_t)(int8_t)x; - res |= (uint32_t)(int8_t)(x >> 16) << 16; - return res; -} - -uint32_t HELPER(uxtb16)(uint32_t x) -{ - uint32_t res; - res = (uint16_t)(uint8_t)x; - res |= (uint32_t)(uint8_t)(x >> 16) << 16; - return res; -} - -uint32_t HELPER(clz)(uint32_t x) -{ - return clz32(x); -} - -int32_t HELPER(sdiv)(int32_t num, int32_t den) -{ - if (den == 0) - return 0; - if (num == INT_MIN && den == -1) - return INT_MIN; - return num / den; -} - -uint32_t HELPER(udiv)(uint32_t num, uint32_t den) -{ - if (den == 0) - return 0; - return num / den; -} - -uint32_t HELPER(rbit)(uint32_t x) -{ - x = ((x & 0xff000000) >> 24) - | ((x & 0x00ff0000) >> 8) - | ((x & 0x0000ff00) << 8) - | ((x & 0x000000ff) << 24); - x = ((x & 0xf0f0f0f0) >> 4) - | ((x & 0x0f0f0f0f) << 4); - x = ((x & 0x88888888) >> 3) - | ((x & 0x44444444) >> 1) - | ((x & 0x22222222) << 1) - | ((x & 0x11111111) << 3); - return x; -} - -uint32_t HELPER(abs)(uint32_t x) -{ - return ((int32_t)x < 0) ? -x : x; -} - -#if defined(CONFIG_USER_ONLY) - -void do_interrupt (CPUState *env) -{ - env->exception_index = -1; -} - -int cpu_arm_handle_mmu_fault (CPUState *env, target_ulong address, int rw, - int mmu_idx, int is_softmmu) -{ - if (rw == 2) { - env->exception_index = EXCP_PREFETCH_ABORT; - env->cp15.c6_insn = address; - } else { - env->exception_index = EXCP_DATA_ABORT; - env->cp15.c6_data = address; - } - return 1; -} - -target_phys_addr_t cpu_get_phys_page_debug(CPUState *env, target_ulong addr) -{ - return addr; -} - -/* These should probably raise undefined insn exceptions. */ -void HELPER(set_cp)(CPUState *env, uint32_t insn, uint32_t val) -{ - int op1 = (insn >> 8) & 0xf; - cpu_abort(env, "cp%i insn %08x\n", op1, insn); - return; -} - -uint32_t HELPER(get_cp)(CPUState *env, uint32_t insn) -{ - int op1 = (insn >> 8) & 0xf; - cpu_abort(env, "cp%i insn %08x\n", op1, insn); - return 0; -} - -void HELPER(set_cp15)(CPUState *env, uint32_t insn, uint32_t val) -{ - cpu_abort(env, "cp15 insn %08x\n", insn); -} - -uint32_t HELPER(get_cp15)(CPUState *env, uint32_t insn) -{ - cpu_abort(env, "cp15 insn %08x\n", insn); - return 0; -} - -/* These should probably raise undefined insn exceptions. */ -void HELPER(v7m_msr)(CPUState *env, uint32_t reg, uint32_t val) -{ - cpu_abort(env, "v7m_mrs %d\n", reg); -} - -uint32_t HELPER(v7m_mrs)(CPUState *env, uint32_t reg) -{ - cpu_abort(env, "v7m_mrs %d\n", reg); - return 0; -} - -void switch_mode(CPUState *env, int mode) -{ - if (mode != ARM_CPU_MODE_USR) - cpu_abort(env, "Tried to switch out of user mode\n"); -} - -void HELPER(set_r13_banked)(CPUState *env, uint32_t mode, uint32_t val) -{ - cpu_abort(env, "banked r13 write\n"); -} - -uint32_t HELPER(get_r13_banked)(CPUState *env, uint32_t mode) -{ - cpu_abort(env, "banked r13 read\n"); - return 0; -} - -#else - -extern int semihosting_enabled; - -/* Map CPU modes onto saved register banks. */ -static inline int bank_number (int mode) -{ - switch (mode) { - case ARM_CPU_MODE_USR: - case ARM_CPU_MODE_SYS: - return 0; - case ARM_CPU_MODE_SVC: - return 1; - case ARM_CPU_MODE_ABT: - return 2; - case ARM_CPU_MODE_UND: - return 3; - case ARM_CPU_MODE_IRQ: - return 4; - case ARM_CPU_MODE_FIQ: - return 5; - } - cpu_abort(cpu_single_env, "Bad mode %x\n", mode); - return -1; -} - -void switch_mode(CPUState *env, int mode) -{ - int old_mode; - int i; - - old_mode = env->uncached_cpsr & CPSR_M; - if (mode == old_mode) - return; - - if (old_mode == ARM_CPU_MODE_FIQ) { - memcpy (env->fiq_regs, env->regs + 8, 5 * sizeof(uint32_t)); - memcpy (env->regs + 8, env->usr_regs, 5 * sizeof(uint32_t)); - } else if (mode == ARM_CPU_MODE_FIQ) { - memcpy (env->usr_regs, env->regs + 8, 5 * sizeof(uint32_t)); - memcpy (env->regs + 8, env->fiq_regs, 5 * sizeof(uint32_t)); - } - - i = bank_number(old_mode); - env->banked_r13[i] = env->regs[13]; - env->banked_r14[i] = env->regs[14]; - env->banked_spsr[i] = env->spsr; - - i = bank_number(mode); - env->regs[13] = env->banked_r13[i]; - env->regs[14] = env->banked_r14[i]; - env->spsr = env->banked_spsr[i]; -} - -static void v7m_push(CPUARMState *env, uint32_t val) -{ - env->regs[13] -= 4; - stl_phys(env->regs[13], val); -} - -static uint32_t v7m_pop(CPUARMState *env) -{ - uint32_t val; - val = ldl_phys(env->regs[13]); - env->regs[13] += 4; - return val; -} - -/* Switch to V7M main or process stack pointer. */ -static void switch_v7m_sp(CPUARMState *env, int process) -{ - uint32_t tmp; - if (env->v7m.current_sp != process) { - tmp = env->v7m.other_sp; - env->v7m.other_sp = env->regs[13]; - env->regs[13] = tmp; - env->v7m.current_sp = process; - } -} - -static void do_v7m_exception_exit(CPUARMState *env) -{ - uint32_t type; - uint32_t xpsr; - - type = env->regs[15]; - if (env->v7m.exception != 0) - armv7m_nvic_complete_irq(env->v7m.nvic, env->v7m.exception); - - /* Switch to the target stack. */ - switch_v7m_sp(env, (type & 4) != 0); - /* Pop registers. */ - env->regs[0] = v7m_pop(env); - env->regs[1] = v7m_pop(env); - env->regs[2] = v7m_pop(env); - env->regs[3] = v7m_pop(env); - env->regs[12] = v7m_pop(env); - env->regs[14] = v7m_pop(env); - env->regs[15] = v7m_pop(env); - xpsr = v7m_pop(env); - xpsr_write(env, xpsr, 0xfffffdff); - /* Undo stack alignment. */ - if (xpsr & 0x200) - env->regs[13] |= 4; - /* ??? The exception return type specifies Thread/Handler mode. However - this is also implied by the xPSR value. Not sure what to do - if there is a mismatch. */ - /* ??? Likewise for mismatches between the CONTROL register and the stack - pointer. */ -} - -static void do_interrupt_v7m(CPUARMState *env) -{ - uint32_t xpsr = xpsr_read(env); - uint32_t lr; - uint32_t addr; - - lr = 0xfffffff1; - if (env->v7m.current_sp) - lr |= 4; - if (env->v7m.exception == 0) - lr |= 8; - - /* For exceptions we just mark as pending on the NVIC, and let that - handle it. */ - /* TODO: Need to escalate if the current priority is higher than the - one we're raising. */ - switch (env->exception_index) { - case EXCP_UDEF: - armv7m_nvic_set_pending(env->v7m.nvic, ARMV7M_EXCP_USAGE); - return; - case EXCP_SWI: - env->regs[15] += 2; - armv7m_nvic_set_pending(env->v7m.nvic, ARMV7M_EXCP_SVC); - return; - case EXCP_PREFETCH_ABORT: - case EXCP_DATA_ABORT: - armv7m_nvic_set_pending(env->v7m.nvic, ARMV7M_EXCP_MEM); - return; - case EXCP_BKPT: - if (semihosting_enabled) { - int nr; - nr = lduw_code(env->regs[15]) & 0xff; - if (nr == 0xab) { - env->regs[15] += 2; - env->regs[0] = do_arm_semihosting(env); - return; - } - } - armv7m_nvic_set_pending(env->v7m.nvic, ARMV7M_EXCP_DEBUG); - return; - case EXCP_IRQ: - env->v7m.exception = armv7m_nvic_acknowledge_irq(env->v7m.nvic); - break; - case EXCP_EXCEPTION_EXIT: - do_v7m_exception_exit(env); - return; - default: - cpu_abort(env, "Unhandled exception 0x%x\n", env->exception_index); - return; /* Never happens. Keep compiler happy. */ - } - - /* Align stack pointer. */ - /* ??? Should only do this if Configuration Control Register - STACKALIGN bit is set. */ - if (env->regs[13] & 4) { - env->regs[13] -= 4; - xpsr |= 0x200; - } - /* Switch to the handler mode. */ - v7m_push(env, xpsr); - v7m_push(env, env->regs[15]); - v7m_push(env, env->regs[14]); - v7m_push(env, env->regs[12]); - v7m_push(env, env->regs[3]); - v7m_push(env, env->regs[2]); - v7m_push(env, env->regs[1]); - v7m_push(env, env->regs[0]); - switch_v7m_sp(env, 0); - env->uncached_cpsr &= ~CPSR_IT; - env->regs[14] = lr; - addr = ldl_phys(env->v7m.vecbase + env->v7m.exception * 4); - env->regs[15] = addr & 0xfffffffe; - env->thumb = addr & 1; -} - -/* Handle a CPU exception. */ -void do_interrupt(CPUARMState *env) -{ - uint32_t addr; - uint32_t mask; - int new_mode; - uint32_t offset; - - if (IS_M(env)) { - do_interrupt_v7m(env); - return; - } - /* TODO: Vectored interrupt controller. */ - switch (env->exception_index) { - case EXCP_UDEF: - new_mode = ARM_CPU_MODE_UND; - addr = 0x04; - mask = CPSR_I; - if (env->thumb) - offset = 2; - else - offset = 4; - break; - case EXCP_SWI: - if (semihosting_enabled) { - /* Check for semihosting interrupt. */ - if (env->thumb) { - mask = lduw_code(env->regs[15] - 2) & 0xff; - } else { - mask = ldl_code(env->regs[15] - 4) & 0xffffff; - } - /* Only intercept calls from privileged modes, to provide some - semblance of security. */ - if (((mask == 0x123456 && !env->thumb) - || (mask == 0xab && env->thumb)) - && (env->uncached_cpsr & CPSR_M) != ARM_CPU_MODE_USR) { - env->regs[0] = do_arm_semihosting(env); - return; - } - } - new_mode = ARM_CPU_MODE_SVC; - addr = 0x08; - mask = CPSR_I; - /* The PC already points to the next instruction. */ - offset = 0; - break; - case EXCP_BKPT: - /* See if this is a semihosting syscall. */ - if (env->thumb && semihosting_enabled) { - mask = lduw_code(env->regs[15]) & 0xff; - if (mask == 0xab - && (env->uncached_cpsr & CPSR_M) != ARM_CPU_MODE_USR) { - env->regs[15] += 2; - env->regs[0] = do_arm_semihosting(env); - return; - } - } - /* Fall through to prefetch abort. */ - case EXCP_PREFETCH_ABORT: - new_mode = ARM_CPU_MODE_ABT; - addr = 0x0c; - mask = CPSR_A | CPSR_I; - offset = 4; - break; - case EXCP_DATA_ABORT: - new_mode = ARM_CPU_MODE_ABT; - addr = 0x10; - mask = CPSR_A | CPSR_I; - offset = 8; - break; - case EXCP_IRQ: - new_mode = ARM_CPU_MODE_IRQ; - addr = 0x18; - /* Disable IRQ and imprecise data aborts. */ - mask = CPSR_A | CPSR_I; - offset = 4; - break; - case EXCP_FIQ: - new_mode = ARM_CPU_MODE_FIQ; - addr = 0x1c; - /* Disable FIQ, IRQ and imprecise data aborts. */ - mask = CPSR_A | CPSR_I | CPSR_F; - offset = 4; - break; - default: - cpu_abort(env, "Unhandled exception 0x%x\n", env->exception_index); - return; /* Never happens. Keep compiler happy. */ - } - /* High vectors. */ - if (env->cp15.c1_sys & (1 << 13)) { - addr += 0xffff0000; - } - switch_mode (env, new_mode); - env->spsr = cpsr_read(env); - /* Clear IT bits. */ - env->condexec_bits = 0; - /* Switch to the new mode, and switch to Arm mode. */ - /* ??? Thumb interrupt handlers not implemented. */ - env->uncached_cpsr = (env->uncached_cpsr & ~CPSR_M) | new_mode; - env->uncached_cpsr |= mask; - env->thumb = 0; - env->regs[14] = env->regs[15] + offset; - env->regs[15] = addr; - env->interrupt_request |= CPU_INTERRUPT_EXITTB; -} - -/* Check section/page access permissions. - Returns the page protection flags, or zero if the access is not - permitted. */ -static inline int check_ap(CPUState *env, int ap, int domain, int access_type, - int is_user) -{ - int prot_ro; - - if (domain == 3) - return PAGE_READ | PAGE_WRITE; - - if (access_type == 1) - prot_ro = 0; - else - prot_ro = PAGE_READ; - - switch (ap) { - case 0: - if (access_type == 1) - return 0; - switch ((env->cp15.c1_sys >> 8) & 3) { - case 1: - return is_user ? 0 : PAGE_READ; - case 2: - return PAGE_READ; - default: - return 0; - } - case 1: - return is_user ? 0 : PAGE_READ | PAGE_WRITE; - case 2: - if (is_user) - return prot_ro; - else - return PAGE_READ | PAGE_WRITE; - case 3: - return PAGE_READ | PAGE_WRITE; - case 4: /* Reserved. */ - return 0; - case 5: - return is_user ? 0 : prot_ro; - case 6: - return prot_ro; - case 7: - if (!arm_feature (env, ARM_FEATURE_V7)) - return 0; - return prot_ro; - default: - abort(); - } -} - -static uint32_t get_level1_table_address(CPUState *env, uint32_t address) -{ - uint32_t table; - - if (address & env->cp15.c2_mask) - table = env->cp15.c2_base1 & 0xffffc000; - else - table = env->cp15.c2_base0 & env->cp15.c2_base_mask; - - table |= (address >> 18) & 0x3ffc; - return table; -} - -static int get_phys_addr_v5(CPUState *env, uint32_t address, int access_type, - int is_user, uint32_t *phys_ptr, int *prot) -{ - int code; - uint32_t table; - uint32_t desc; - int type; - int ap; - int domain; - uint32_t phys_addr; - - /* Pagetable walk. */ - /* Lookup l1 descriptor. */ - table = get_level1_table_address(env, address); - desc = ldl_phys(table); - type = (desc & 3); - domain = (env->cp15.c3 >> ((desc >> 4) & 0x1e)) & 3; - if (type == 0) { - /* Section translation fault. */ - code = 5; - goto do_fault; - } - if (domain == 0 || domain == 2) { - if (type == 2) - code = 9; /* Section domain fault. */ - else - code = 11; /* Page domain fault. */ - goto do_fault; - } - if (type == 2) { - /* 1Mb section. */ - phys_addr = (desc & 0xfff00000) | (address & 0x000fffff); - ap = (desc >> 10) & 3; - code = 13; - } else { - /* Lookup l2 entry. */ - if (type == 1) { - /* Coarse pagetable. */ - table = (desc & 0xfffffc00) | ((address >> 10) & 0x3fc); - } else { - /* Fine pagetable. */ - table = (desc & 0xfffff000) | ((address >> 8) & 0xffc); - } - desc = ldl_phys(table); - switch (desc & 3) { - case 0: /* Page translation fault. */ - code = 7; - goto do_fault; - case 1: /* 64k page. */ - phys_addr = (desc & 0xffff0000) | (address & 0xffff); - ap = (desc >> (4 + ((address >> 13) & 6))) & 3; - break; - case 2: /* 4k page. */ - phys_addr = (desc & 0xfffff000) | (address & 0xfff); - ap = (desc >> (4 + ((address >> 13) & 6))) & 3; - break; - case 3: /* 1k page. */ - if (type == 1) { - if (arm_feature(env, ARM_FEATURE_XSCALE)) { - phys_addr = (desc & 0xfffff000) | (address & 0xfff); - } else { - /* Page translation fault. */ - code = 7; - goto do_fault; - } - } else { - phys_addr = (desc & 0xfffffc00) | (address & 0x3ff); - } - ap = (desc >> 4) & 3; - break; - default: - /* Never happens, but compiler isn't smart enough to tell. */ - abort(); - } - code = 15; - } - *prot = check_ap(env, ap, domain, access_type, is_user); - if (!*prot) { - /* Access permission fault. */ - goto do_fault; - } - *phys_ptr = phys_addr; - return 0; -do_fault: - return code | (domain << 4); -} - -static int get_phys_addr_v6(CPUState *env, uint32_t address, int access_type, - int is_user, uint32_t *phys_ptr, int *prot) -{ - int code; - uint32_t table; - uint32_t desc; - uint32_t xn; - int type; - int ap; - int domain; - uint32_t phys_addr; - - /* Pagetable walk. */ - /* Lookup l1 descriptor. */ - table = get_level1_table_address(env, address); - desc = ldl_phys(table); - type = (desc & 3); - if (type == 0) { - /* Section translation fault. */ - code = 5; - domain = 0; - goto do_fault; - } else if (type == 2 && (desc & (1 << 18))) { - /* Supersection. */ - domain = 0; - } else { - /* Section or page. */ - domain = (desc >> 4) & 0x1e; - } - domain = (env->cp15.c3 >> domain) & 3; - if (domain == 0 || domain == 2) { - if (type == 2) - code = 9; /* Section domain fault. */ - else - code = 11; /* Page domain fault. */ - goto do_fault; - } - if (type == 2) { - if (desc & (1 << 18)) { - /* Supersection. */ - phys_addr = (desc & 0xff000000) | (address & 0x00ffffff); - } else { - /* Section. */ - phys_addr = (desc & 0xfff00000) | (address & 0x000fffff); - } - ap = ((desc >> 10) & 3) | ((desc >> 13) & 4); - xn = desc & (1 << 4); - code = 13; - } else { - /* Lookup l2 entry. */ - table = (desc & 0xfffffc00) | ((address >> 10) & 0x3fc); - desc = ldl_phys(table); - ap = ((desc >> 4) & 3) | ((desc >> 7) & 4); - switch (desc & 3) { - case 0: /* Page translation fault. */ - code = 7; - goto do_fault; - case 1: /* 64k page. */ - phys_addr = (desc & 0xffff0000) | (address & 0xffff); - xn = desc & (1 << 15); - break; - case 2: case 3: /* 4k page. */ - phys_addr = (desc & 0xfffff000) | (address & 0xfff); - xn = desc & 1; - break; - default: - /* Never happens, but compiler isn't smart enough to tell. */ - abort(); - } - code = 15; - } - if (xn && access_type == 2) - goto do_fault; - - /* The simplified model uses AP[0] as an access control bit. */ - if ((env->cp15.c1_sys & (1 << 29)) && (ap & 1) == 0) { - /* Access flag fault. */ - code = (code == 15) ? 6 : 3; - goto do_fault; - } - *prot = check_ap(env, ap, domain, access_type, is_user); - if (!*prot) { - /* Access permission fault. */ - goto do_fault; - } - *phys_ptr = phys_addr; - return 0; -do_fault: - return code | (domain << 4); -} - -static int get_phys_addr_mpu(CPUState *env, uint32_t address, int access_type, - int is_user, uint32_t *phys_ptr, int *prot) -{ - int n; - uint32_t mask; - uint32_t base; - - *phys_ptr = address; - for (n = 7; n >= 0; n--) { - base = env->cp15.c6_region[n]; - if ((base & 1) == 0) - continue; - mask = 1 << ((base >> 1) & 0x1f); - /* Keep this shift separate from the above to avoid an - (undefined) << 32. */ - mask = (mask << 1) - 1; - if (((base ^ address) & ~mask) == 0) - break; - } - if (n < 0) - return 2; - - if (access_type == 2) { - mask = env->cp15.c5_insn; - } else { - mask = env->cp15.c5_data; - } - mask = (mask >> (n * 4)) & 0xf; - switch (mask) { - case 0: - return 1; - case 1: - if (is_user) - return 1; - *prot = PAGE_READ | PAGE_WRITE; - break; - case 2: - *prot = PAGE_READ; - if (!is_user) - *prot |= PAGE_WRITE; - break; - case 3: - *prot = PAGE_READ | PAGE_WRITE; - break; - case 5: - if (is_user) - return 1; - *prot = PAGE_READ; - break; - case 6: - *prot = PAGE_READ; - break; - default: - /* Bad permission. */ - return 1; - } - return 0; -} - -static inline int get_phys_addr(CPUState *env, uint32_t address, - int access_type, int is_user, - uint32_t *phys_ptr, int *prot) -{ - /* Fast Context Switch Extension. */ - if (address < 0x02000000) - address += env->cp15.c13_fcse; - - if ((env->cp15.c1_sys & 1) == 0) { - /* MMU/MPU disabled. */ - *phys_ptr = address; - *prot = PAGE_READ | PAGE_WRITE; - return 0; - } else if (arm_feature(env, ARM_FEATURE_MPU)) { - return get_phys_addr_mpu(env, address, access_type, is_user, phys_ptr, - prot); - } else if (env->cp15.c1_sys & (1 << 23)) { - return get_phys_addr_v6(env, address, access_type, is_user, phys_ptr, - prot); - } else { - return get_phys_addr_v5(env, address, access_type, is_user, phys_ptr, - prot); - } -} - -int cpu_arm_handle_mmu_fault (CPUState *env, target_ulong address, - int access_type, int mmu_idx, int is_softmmu) -{ - uint32_t phys_addr; - int prot; - int ret, is_user; - - is_user = mmu_idx == MMU_USER_IDX; - ret = get_phys_addr(env, address, access_type, is_user, &phys_addr, &prot); - if (ret == 0) { - /* Map a single [sub]page. */ - phys_addr &= ~(uint32_t)0x3ff; - address &= ~(uint32_t)0x3ff; - return tlb_set_page (env, address, phys_addr, prot, mmu_idx, - is_softmmu); - } - - if (access_type == 2) { - env->cp15.c5_insn = ret; - env->cp15.c6_insn = address; - env->exception_index = EXCP_PREFETCH_ABORT; - } else { - env->cp15.c5_data = ret; - if (access_type == 1 && arm_feature(env, ARM_FEATURE_V6)) - env->cp15.c5_data |= (1 << 11); - env->cp15.c6_data = address; - env->exception_index = EXCP_DATA_ABORT; - } - return 1; -} - -target_phys_addr_t cpu_get_phys_page_debug(CPUState *env, target_ulong addr) -{ - uint32_t phys_addr; - int prot; - int ret; - - ret = get_phys_addr(env, addr, 0, 0, &phys_addr, &prot); - - if (ret != 0) - return -1; - - return phys_addr; -} - -void HELPER(set_cp)(CPUState *env, uint32_t insn, uint32_t val) -{ - int cp_num = (insn >> 8) & 0xf; - int cp_info = (insn >> 5) & 7; - int src = (insn >> 16) & 0xf; - int operand = insn & 0xf; - - if (env->cp[cp_num].cp_write) - env->cp[cp_num].cp_write(env->cp[cp_num].opaque, - cp_info, src, operand, val); -} - -uint32_t HELPER(get_cp)(CPUState *env, uint32_t insn) -{ - int cp_num = (insn >> 8) & 0xf; - int cp_info = (insn >> 5) & 7; - int dest = (insn >> 16) & 0xf; - int operand = insn & 0xf; - - if (env->cp[cp_num].cp_read) - return env->cp[cp_num].cp_read(env->cp[cp_num].opaque, - cp_info, dest, operand); - return 0; -} - -/* Return basic MPU access permission bits. */ -static uint32_t simple_mpu_ap_bits(uint32_t val) -{ - uint32_t ret; - uint32_t mask; - int i; - ret = 0; - mask = 3; - for (i = 0; i < 16; i += 2) { - ret |= (val >> i) & mask; - mask <<= 2; - } - return ret; -} - -/* Pad basic MPU access permission bits to extended format. */ -static uint32_t extended_mpu_ap_bits(uint32_t val) -{ - uint32_t ret; - uint32_t mask; - int i; - ret = 0; - mask = 3; - for (i = 0; i < 16; i += 2) { - ret |= (val & mask) << i; - mask <<= 2; - } - return ret; -} - -void HELPER(set_cp15)(CPUState *env, uint32_t insn, uint32_t val) -{ - int op1; - int op2; - int crm; - - op1 = (insn >> 21) & 7; - op2 = (insn >> 5) & 7; - crm = insn & 0xf; - switch ((insn >> 16) & 0xf) { - case 0: - /* ID codes. */ - if (arm_feature(env, ARM_FEATURE_XSCALE)) - break; - if (arm_feature(env, ARM_FEATURE_OMAPCP)) - break; - if (arm_feature(env, ARM_FEATURE_V7) - && op1 == 2 && crm == 0 && op2 == 0) { - env->cp15.c0_cssel = val & 0xf; - break; - } - goto bad_reg; - case 1: /* System configuration. */ - if (arm_feature(env, ARM_FEATURE_OMAPCP)) - op2 = 0; - switch (op2) { - case 0: - if (!arm_feature(env, ARM_FEATURE_XSCALE) || crm == 0) - env->cp15.c1_sys = val; - /* ??? Lots of these bits are not implemented. */ - /* This may enable/disable the MMU, so do a TLB flush. */ - tlb_flush(env, 1); - break; - case 1: /* Auxiliary cotrol register. */ - if (arm_feature(env, ARM_FEATURE_XSCALE)) { - env->cp15.c1_xscaleauxcr = val; - break; - } - /* Not implemented. */ - break; - case 2: - if (arm_feature(env, ARM_FEATURE_XSCALE)) - goto bad_reg; - if (env->cp15.c1_coproc != val) { - env->cp15.c1_coproc = val; - /* ??? Is this safe when called from within a TB? */ - tb_flush(env); - } - break; - default: - goto bad_reg; - } - break; - case 2: /* MMU Page table control / MPU cache control. */ - if (arm_feature(env, ARM_FEATURE_MPU)) { - switch (op2) { - case 0: - env->cp15.c2_data = val; - break; - case 1: - env->cp15.c2_insn = val; - break; - default: - goto bad_reg; - } - } else { - switch (op2) { - case 0: - env->cp15.c2_base0 = val; - break; - case 1: - env->cp15.c2_base1 = val; - break; - case 2: - val &= 7; - env->cp15.c2_control = val; - env->cp15.c2_mask = ~(((uint32_t)0xffffffffu) >> val); - env->cp15.c2_base_mask = ~((uint32_t)0x3fffu >> val); - break; - default: - goto bad_reg; - } - } - break; - case 3: /* MMU Domain access control / MPU write buffer control. */ - env->cp15.c3 = val; - tlb_flush(env, 1); /* Flush TLB as domain not tracked in TLB */ - break; - case 4: /* Reserved. */ - goto bad_reg; - case 5: /* MMU Fault status / MPU access permission. */ - if (arm_feature(env, ARM_FEATURE_OMAPCP)) - op2 = 0; - switch (op2) { - case 0: - if (arm_feature(env, ARM_FEATURE_MPU)) - val = extended_mpu_ap_bits(val); - env->cp15.c5_data = val; - break; - case 1: - if (arm_feature(env, ARM_FEATURE_MPU)) - val = extended_mpu_ap_bits(val); - env->cp15.c5_insn = val; - break; - case 2: - if (!arm_feature(env, ARM_FEATURE_MPU)) - goto bad_reg; - env->cp15.c5_data = val; - break; - case 3: - if (!arm_feature(env, ARM_FEATURE_MPU)) - goto bad_reg; - env->cp15.c5_insn = val; - break; - default: - goto bad_reg; - } - break; - case 6: /* MMU Fault address / MPU base/size. */ - if (arm_feature(env, ARM_FEATURE_MPU)) { - if (crm >= 8) - goto bad_reg; - env->cp15.c6_region[crm] = val; - } else { - if (arm_feature(env, ARM_FEATURE_OMAPCP)) - op2 = 0; - switch (op2) { - case 0: - env->cp15.c6_data = val; - break; - case 1: /* ??? This is WFAR on armv6 */ - case 2: - env->cp15.c6_insn = val; - break; - default: - goto bad_reg; - } - } - break; - case 7: /* Cache control. */ - env->cp15.c15_i_max = 0x000; - env->cp15.c15_i_min = 0xff0; - /* No cache, so nothing to do. */ - /* ??? MPCore has VA to PA translation functions. */ - break; - case 8: /* MMU TLB control. */ - switch (op2) { - case 0: /* Invalidate all. */ - tlb_flush(env, 0); - break; - case 1: /* Invalidate single TLB entry. */ -#if 0 - /* ??? This is wrong for large pages and sections. */ - /* As an ugly hack to make linux work we always flush a 4K - pages. */ - val &= 0xfffff000; - tlb_flush_page(env, val); - tlb_flush_page(env, val + 0x400); - tlb_flush_page(env, val + 0x800); - tlb_flush_page(env, val + 0xc00); -#else - tlb_flush(env, 1); -#endif - break; - case 2: /* Invalidate on ASID. */ - tlb_flush(env, val == 0); - break; - case 3: /* Invalidate single entry on MVA. */ - /* ??? This is like case 1, but ignores ASID. */ - tlb_flush(env, 1); - break; - default: - goto bad_reg; - } - break; - case 9: - if (arm_feature(env, ARM_FEATURE_OMAPCP)) - break; - switch (crm) { - case 0: /* Cache lockdown. */ - switch (op1) { - case 0: /* L1 cache. */ - switch (op2) { - case 0: - env->cp15.c9_data = val; - break; - case 1: - env->cp15.c9_insn = val; - break; - default: - goto bad_reg; - } - break; - case 1: /* L2 cache. */ - /* Ignore writes to L2 lockdown/auxiliary registers. */ - break; - default: - goto bad_reg; - } - break; - case 1: /* TCM memory region registers. */ - /* Not implemented. */ - goto bad_reg; - default: - goto bad_reg; - } - break; - case 10: /* MMU TLB lockdown. */ - /* ??? TLB lockdown not implemented. */ - break; - case 12: /* Reserved. */ - goto bad_reg; - case 13: /* Process ID. */ - switch (op2) { - case 0: - /* Unlike real hardware the qemu TLB uses virtual addresses, - not modified virtual addresses, so this causes a TLB flush. - */ - if (env->cp15.c13_fcse != val) - tlb_flush(env, 1); - env->cp15.c13_fcse = val; - break; - case 1: - /* This changes the ASID, so do a TLB flush. */ - if (env->cp15.c13_context != val - && !arm_feature(env, ARM_FEATURE_MPU)) - tlb_flush(env, 0); - env->cp15.c13_context = val; - break; - case 2: - env->cp15.c13_tls1 = val; - break; - case 3: - env->cp15.c13_tls2 = val; - break; - case 4: - env->cp15.c13_tls3 = val; - break; - default: - goto bad_reg; - } - break; - case 14: /* Reserved. */ - goto bad_reg; - case 15: /* Implementation specific. */ - if (arm_feature(env, ARM_FEATURE_XSCALE)) { - if (op2 == 0 && crm == 1) { - if (env->cp15.c15_cpar != (val & 0x3fff)) { - /* Changes cp0 to cp13 behavior, so needs a TB flush. */ - tb_flush(env); - env->cp15.c15_cpar = val & 0x3fff; - } - break; - } - goto bad_reg; - } - if (arm_feature(env, ARM_FEATURE_OMAPCP)) { - switch (crm) { - case 0: - break; - case 1: /* Set TI925T configuration. */ - env->cp15.c15_ticonfig = val & 0xe7; - env->cp15.c0_cpuid = (val & (1 << 5)) ? /* OS_TYPE bit */ - ARM_CPUID_TI915T : ARM_CPUID_TI925T; - break; - case 2: /* Set I_max. */ - env->cp15.c15_i_max = val; - break; - case 3: /* Set I_min. */ - env->cp15.c15_i_min = val; - break; - case 4: /* Set thread-ID. */ - env->cp15.c15_threadid = val & 0xffff; - break; - case 8: /* Wait-for-interrupt (deprecated). */ - cpu_interrupt(env, CPU_INTERRUPT_HALT); - break; - default: - goto bad_reg; - } - } - break; - } - return; -bad_reg: - /* ??? For debugging only. Should raise illegal instruction exception. */ - cpu_abort(env, "Unimplemented cp15 register write (c%d, c%d, {%d, %d})\n", - (insn >> 16) & 0xf, crm, op1, op2); -} - -uint32_t HELPER(get_cp15)(CPUState *env, uint32_t insn) -{ - int op1; - int op2; - int crm; - - op1 = (insn >> 21) & 7; - op2 = (insn >> 5) & 7; - crm = insn & 0xf; - switch ((insn >> 16) & 0xf) { - case 0: /* ID codes. */ - switch (op1) { - case 0: - switch (crm) { - case 0: - switch (op2) { - case 0: /* Device ID. */ - return env->cp15.c0_cpuid; - case 1: /* Cache Type. */ - return env->cp15.c0_cachetype; - case 2: /* TCM status. */ - return 0; - case 3: /* TLB type register. */ - return 0; /* No lockable TLB entries. */ - case 5: /* CPU ID */ - if (ARM_CPUID(env) == ARM_CPUID_CORTEXA9) { - return env->cpu_index | 0x80000900; - } else { - return env->cpu_index; - } - default: - goto bad_reg; - } - case 1: - if (!arm_feature(env, ARM_FEATURE_V6)) - goto bad_reg; - return env->cp15.c0_c1[op2]; - case 2: - if (!arm_feature(env, ARM_FEATURE_V6)) - goto bad_reg; - return env->cp15.c0_c2[op2]; - case 3: case 4: case 5: case 6: case 7: - return 0; - default: - goto bad_reg; - } - case 1: - /* These registers aren't documented on arm11 cores. However - Linux looks at them anyway. */ - if (!arm_feature(env, ARM_FEATURE_V6)) - goto bad_reg; - if (crm != 0) - goto bad_reg; - if (!arm_feature(env, ARM_FEATURE_V7)) - return 0; - - switch (op2) { - case 0: - return env->cp15.c0_ccsid[env->cp15.c0_cssel]; - case 1: - return env->cp15.c0_clid; - case 7: - return 0; - } - goto bad_reg; - case 2: - if (op2 != 0 || crm != 0) - goto bad_reg; - return env->cp15.c0_cssel; - default: - goto bad_reg; - } - case 1: /* System configuration. */ - if (arm_feature(env, ARM_FEATURE_OMAPCP)) - op2 = 0; - switch (op2) { - case 0: /* Control register. */ - return env->cp15.c1_sys; - case 1: /* Auxiliary control register. */ - if (arm_feature(env, ARM_FEATURE_XSCALE)) - return env->cp15.c1_xscaleauxcr; - if (!arm_feature(env, ARM_FEATURE_AUXCR)) - goto bad_reg; - switch (ARM_CPUID(env)) { - case ARM_CPUID_ARM1026: - return 1; - case ARM_CPUID_ARM1136: - case ARM_CPUID_ARM1136_R2: - return 7; - case ARM_CPUID_ARM11MPCORE: - return 1; - case ARM_CPUID_CORTEXA8: - return 2; - case ARM_CPUID_CORTEXA9: - return 0; - default: - goto bad_reg; - } - case 2: /* Coprocessor access register. */ - if (arm_feature(env, ARM_FEATURE_XSCALE)) - goto bad_reg; - return env->cp15.c1_coproc; - default: - goto bad_reg; - } - case 2: /* MMU Page table control / MPU cache control. */ - if (arm_feature(env, ARM_FEATURE_MPU)) { - switch (op2) { - case 0: - return env->cp15.c2_data; - break; - case 1: - return env->cp15.c2_insn; - break; - default: - goto bad_reg; - } - } else { - switch (op2) { - case 0: - return env->cp15.c2_base0; - case 1: - return env->cp15.c2_base1; - case 2: - return env->cp15.c2_control; - default: - goto bad_reg; - } - } - case 3: /* MMU Domain access control / MPU write buffer control. */ - return env->cp15.c3; - case 4: /* Reserved. */ - goto bad_reg; - case 5: /* MMU Fault status / MPU access permission. */ - if (arm_feature(env, ARM_FEATURE_OMAPCP)) - op2 = 0; - switch (op2) { - case 0: - if (arm_feature(env, ARM_FEATURE_MPU)) - return simple_mpu_ap_bits(env->cp15.c5_data); - return env->cp15.c5_data; - case 1: - if (arm_feature(env, ARM_FEATURE_MPU)) - return simple_mpu_ap_bits(env->cp15.c5_data); - return env->cp15.c5_insn; - case 2: - if (!arm_feature(env, ARM_FEATURE_MPU)) - goto bad_reg; - return env->cp15.c5_data; - case 3: - if (!arm_feature(env, ARM_FEATURE_MPU)) - goto bad_reg; - return env->cp15.c5_insn; - default: - goto bad_reg; - } - case 6: /* MMU Fault address. */ - if (arm_feature(env, ARM_FEATURE_MPU)) { - if (crm >= 8) - goto bad_reg; - return env->cp15.c6_region[crm]; - } else { - if (arm_feature(env, ARM_FEATURE_OMAPCP)) - op2 = 0; - switch (op2) { - case 0: - return env->cp15.c6_data; - case 1: - if (arm_feature(env, ARM_FEATURE_V6)) { - /* Watchpoint Fault Adrress. */ - return 0; /* Not implemented. */ - } else { - /* Instruction Fault Adrress. */ - /* Arm9 doesn't have an IFAR, but implementing it anyway - shouldn't do any harm. */ - return env->cp15.c6_insn; - } - case 2: - if (arm_feature(env, ARM_FEATURE_V6)) { - /* Instruction Fault Adrress. */ - return env->cp15.c6_insn; - } else { - goto bad_reg; - } - default: - goto bad_reg; - } - } - case 7: /* Cache control. */ - /* FIXME: Should only clear Z flag if destination is r15. */ - env->ZF = 0; - return 0; - case 8: /* MMU TLB control. */ - goto bad_reg; - case 9: /* Cache lockdown. */ - switch (op1) { - case 0: /* L1 cache. */ - if (arm_feature(env, ARM_FEATURE_OMAPCP)) - return 0; - switch (op2) { - case 0: - return env->cp15.c9_data; - case 1: - return env->cp15.c9_insn; - default: - goto bad_reg; - } - case 1: /* L2 cache */ - if (crm != 0) - goto bad_reg; - /* L2 Lockdown and Auxiliary control. */ - return 0; - default: - goto bad_reg; - } - case 10: /* MMU TLB lockdown. */ - /* ??? TLB lockdown not implemented. */ - return 0; - case 11: /* TCM DMA control. */ - case 12: /* Reserved. */ - goto bad_reg; - case 13: /* Process ID. */ - switch (op2) { - case 0: - return env->cp15.c13_fcse; - case 1: - return env->cp15.c13_context; - case 2: - return env->cp15.c13_tls1; - case 3: - return env->cp15.c13_tls2; - case 4: - return env->cp15.c13_tls3; - default: - goto bad_reg; - } - case 14: /* Reserved. */ - goto bad_reg; - case 15: /* Implementation specific. */ - if (arm_feature(env, ARM_FEATURE_XSCALE)) { - if (op2 == 0 && crm == 1) - return env->cp15.c15_cpar; - - goto bad_reg; - } - if (arm_feature(env, ARM_FEATURE_OMAPCP)) { - switch (crm) { - case 0: - return 0; - case 1: /* Read TI925T configuration. */ - return env->cp15.c15_ticonfig; - case 2: /* Read I_max. */ - return env->cp15.c15_i_max; - case 3: /* Read I_min. */ - return env->cp15.c15_i_min; - case 4: /* Read thread-ID. */ - return env->cp15.c15_threadid; - case 8: /* TI925T_status */ - return 0; - } - /* TODO: Peripheral port remap register: - * On OMAP2 mcr p15, 0, rn, c15, c2, 4 sets up the interrupt - * controller base address at $rn & ~0xfff and map size of - * 0x200 << ($rn & 0xfff), when MMU is off. */ - goto bad_reg; - } - return 0; - } -bad_reg: - /* ??? For debugging only. Should raise illegal instruction exception. */ - cpu_abort(env, "Unimplemented cp15 register read (c%d, c%d, {%d, %d})\n", - (insn >> 16) & 0xf, crm, op1, op2); - return 0; -} - -void HELPER(set_r13_banked)(CPUState *env, uint32_t mode, uint32_t val) -{ - env->banked_r13[bank_number(mode)] = val; -} - -uint32_t HELPER(get_r13_banked)(CPUState *env, uint32_t mode) -{ - return env->banked_r13[bank_number(mode)]; -} - -uint32_t HELPER(v7m_mrs)(CPUState *env, uint32_t reg) -{ - switch (reg) { - case 0: /* APSR */ - return xpsr_read(env) & 0xf8000000; - case 1: /* IAPSR */ - return xpsr_read(env) & 0xf80001ff; - case 2: /* EAPSR */ - return xpsr_read(env) & 0xff00fc00; - case 3: /* xPSR */ - return xpsr_read(env) & 0xff00fdff; - case 5: /* IPSR */ - return xpsr_read(env) & 0x000001ff; - case 6: /* EPSR */ - return xpsr_read(env) & 0x0700fc00; - case 7: /* IEPSR */ - return xpsr_read(env) & 0x0700edff; - case 8: /* MSP */ - return env->v7m.current_sp ? env->v7m.other_sp : env->regs[13]; - case 9: /* PSP */ - return env->v7m.current_sp ? env->regs[13] : env->v7m.other_sp; - case 16: /* PRIMASK */ - return (env->uncached_cpsr & CPSR_I) != 0; - case 17: /* FAULTMASK */ - return (env->uncached_cpsr & CPSR_F) != 0; - case 18: /* BASEPRI */ - case 19: /* BASEPRI_MAX */ - return env->v7m.basepri; - case 20: /* CONTROL */ - return env->v7m.control; - default: - /* ??? For debugging only. */ - cpu_abort(env, "Unimplemented system register read (%d)\n", reg); - return 0; - } -} - -void HELPER(v7m_msr)(CPUState *env, uint32_t reg, uint32_t val) -{ - switch (reg) { - case 0: /* APSR */ - xpsr_write(env, val, 0xf8000000); - break; - case 1: /* IAPSR */ - xpsr_write(env, val, 0xf8000000); - break; - case 2: /* EAPSR */ - xpsr_write(env, val, 0xfe00fc00); - break; - case 3: /* xPSR */ - xpsr_write(env, val, 0xfe00fc00); - break; - case 5: /* IPSR */ - /* IPSR bits are readonly. */ - break; - case 6: /* EPSR */ - xpsr_write(env, val, 0x0600fc00); - break; - case 7: /* IEPSR */ - xpsr_write(env, val, 0x0600fc00); - break; - case 8: /* MSP */ - if (env->v7m.current_sp) - env->v7m.other_sp = val; - else - env->regs[13] = val; - break; - case 9: /* PSP */ - if (env->v7m.current_sp) - env->regs[13] = val; - else - env->v7m.other_sp = val; - break; - case 16: /* PRIMASK */ - if (val & 1) - env->uncached_cpsr |= CPSR_I; - else - env->uncached_cpsr &= ~CPSR_I; - break; - case 17: /* FAULTMASK */ - if (val & 1) - env->uncached_cpsr |= CPSR_F; - else - env->uncached_cpsr &= ~CPSR_F; - break; - case 18: /* BASEPRI */ - env->v7m.basepri = val & 0xff; - break; - case 19: /* BASEPRI_MAX */ - val &= 0xff; - if (val != 0 && (val < env->v7m.basepri || env->v7m.basepri == 0)) - env->v7m.basepri = val; - break; - case 20: /* CONTROL */ - env->v7m.control = val & 3; - switch_v7m_sp(env, (val & 2) != 0); - break; - default: - /* ??? For debugging only. */ - cpu_abort(env, "Unimplemented system register write (%d)\n", reg); - return; - } -} - -void cpu_arm_set_cp_io(CPUARMState *env, int cpnum, - ARMReadCPFunc *cp_read, ARMWriteCPFunc *cp_write, - void *opaque) -{ - if (cpnum < 0 || cpnum > 14) { - cpu_abort(env, "Bad coprocessor number: %i\n", cpnum); - return; - } - - env->cp[cpnum].cp_read = cp_read; - env->cp[cpnum].cp_write = cp_write; - env->cp[cpnum].opaque = opaque; -} - -#endif - -/* Note that signed overflow is undefined in C. The following routines are - careful to use unsigned types where modulo arithmetic is required. - Failure to do so _will_ break on newer gcc. */ - -/* Signed saturating arithmetic. */ - -/* Perform 16-bit signed saturating addition. */ -static inline uint16_t add16_sat(uint16_t a, uint16_t b) -{ - uint16_t res; - - res = a + b; - if (((res ^ a) & 0x8000) && !((a ^ b) & 0x8000)) { - if (a & 0x8000) - res = 0x8000; - else - res = 0x7fff; - } - return res; -} - -/* Perform 8-bit signed saturating addition. */ -static inline uint8_t add8_sat(uint8_t a, uint8_t b) -{ - uint8_t res; - - res = a + b; - if (((res ^ a) & 0x80) && !((a ^ b) & 0x80)) { - if (a & 0x80) - res = 0x80; - else - res = 0x7f; - } - return res; -} - -/* Perform 16-bit signed saturating subtraction. */ -static inline uint16_t sub16_sat(uint16_t a, uint16_t b) -{ - uint16_t res; - - res = a - b; - if (((res ^ a) & 0x8000) && ((a ^ b) & 0x8000)) { - if (a & 0x8000) - res = 0x8000; - else - res = 0x7fff; - } - return res; -} - -/* Perform 8-bit signed saturating subtraction. */ -static inline uint8_t sub8_sat(uint8_t a, uint8_t b) -{ - uint8_t res; - - res = a - b; - if (((res ^ a) & 0x80) && ((a ^ b) & 0x80)) { - if (a & 0x80) - res = 0x80; - else - res = 0x7f; - } - return res; -} - -#define ADD16(a, b, n) RESULT(add16_sat(a, b), n, 16); -#define SUB16(a, b, n) RESULT(sub16_sat(a, b), n, 16); -#define ADD8(a, b, n) RESULT(add8_sat(a, b), n, 8); -#define SUB8(a, b, n) RESULT(sub8_sat(a, b), n, 8); -#define PFX q - -#include "op_addsub.h" - -/* Unsigned saturating arithmetic. */ -static inline uint16_t add16_usat(uint16_t a, uint16_t b) -{ - uint16_t res; - res = a + b; - if (res < a) - res = 0xffff; - return res; -} - -static inline uint16_t sub16_usat(uint16_t a, uint16_t b) -{ - if (a < b) - return a - b; - else - return 0; -} - -static inline uint8_t add8_usat(uint8_t a, uint8_t b) -{ - uint8_t res; - res = a + b; - if (res < a) - res = 0xff; - return res; -} - -static inline uint8_t sub8_usat(uint8_t a, uint8_t b) -{ - if (a < b) - return a - b; - else - return 0; -} - -#define ADD16(a, b, n) RESULT(add16_usat(a, b), n, 16); -#define SUB16(a, b, n) RESULT(sub16_usat(a, b), n, 16); -#define ADD8(a, b, n) RESULT(add8_usat(a, b), n, 8); -#define SUB8(a, b, n) RESULT(sub8_usat(a, b), n, 8); -#define PFX uq - -#include "op_addsub.h" - -/* Signed modulo arithmetic. */ -#define SARITH16(a, b, n, op) do { \ - int32_t sum; \ - sum = (int16_t)((uint16_t)(a) op (uint16_t)(b)); \ - RESULT(sum, n, 16); \ - if (sum >= 0) \ - ge |= 3 << (n * 2); \ - } while(0) - -#define SARITH8(a, b, n, op) do { \ - int32_t sum; \ - sum = (int8_t)((uint8_t)(a) op (uint8_t)(b)); \ - RESULT(sum, n, 8); \ - if (sum >= 0) \ - ge |= 1 << n; \ - } while(0) - - -#define ADD16(a, b, n) SARITH16(a, b, n, +) -#define SUB16(a, b, n) SARITH16(a, b, n, -) -#define ADD8(a, b, n) SARITH8(a, b, n, +) -#define SUB8(a, b, n) SARITH8(a, b, n, -) -#define PFX s -#define ARITH_GE - -#include "op_addsub.h" - -/* Unsigned modulo arithmetic. */ -#define ADD16(a, b, n) do { \ - uint32_t sum; \ - sum = (uint32_t)(uint16_t)(a) + (uint32_t)(uint16_t)(b); \ - RESULT(sum, n, 16); \ - if ((sum >> 16) == 1) \ - ge |= 3 << (n * 2); \ - } while(0) - -#define ADD8(a, b, n) do { \ - uint32_t sum; \ - sum = (uint32_t)(uint8_t)(a) + (uint32_t)(uint8_t)(b); \ - RESULT(sum, n, 8); \ - if ((sum >> 8) == 1) \ - ge |= 1 << n; \ - } while(0) - -#define SUB16(a, b, n) do { \ - uint32_t sum; \ - sum = (uint32_t)(uint16_t)(a) - (uint32_t)(uint16_t)(b); \ - RESULT(sum, n, 16); \ - if ((sum >> 16) == 0) \ - ge |= 3 << (n * 2); \ - } while(0) - -#define SUB8(a, b, n) do { \ - uint32_t sum; \ - sum = (uint32_t)(uint8_t)(a) - (uint32_t)(uint8_t)(b); \ - RESULT(sum, n, 8); \ - if ((sum >> 8) == 0) \ - ge |= 1 << n; \ - } while(0) - -#define PFX u -#define ARITH_GE - -#include "op_addsub.h" - -/* Halved signed arithmetic. */ -#define ADD16(a, b, n) \ - RESULT(((int32_t)(int16_t)(a) + (int32_t)(int16_t)(b)) >> 1, n, 16) -#define SUB16(a, b, n) \ - RESULT(((int32_t)(int16_t)(a) - (int32_t)(int16_t)(b)) >> 1, n, 16) -#define ADD8(a, b, n) \ - RESULT(((int32_t)(int8_t)(a) + (int32_t)(int8_t)(b)) >> 1, n, 8) -#define SUB8(a, b, n) \ - RESULT(((int32_t)(int8_t)(a) - (int32_t)(int8_t)(b)) >> 1, n, 8) -#define PFX sh - -#include "op_addsub.h" - -/* Halved unsigned arithmetic. */ -#define ADD16(a, b, n) \ - RESULT(((uint32_t)(uint16_t)(a) + (uint32_t)(uint16_t)(b)) >> 1, n, 16) -#define SUB16(a, b, n) \ - RESULT(((uint32_t)(uint16_t)(a) - (uint32_t)(uint16_t)(b)) >> 1, n, 16) -#define ADD8(a, b, n) \ - RESULT(((uint32_t)(uint8_t)(a) + (uint32_t)(uint8_t)(b)) >> 1, n, 8) -#define SUB8(a, b, n) \ - RESULT(((uint32_t)(uint8_t)(a) - (uint32_t)(uint8_t)(b)) >> 1, n, 8) -#define PFX uh - -#include "op_addsub.h" - -static inline uint8_t do_usad(uint8_t a, uint8_t b) -{ - if (a > b) - return a - b; - else - return b - a; -} - -/* Unsigned sum of absolute byte differences. */ -uint32_t HELPER(usad8)(uint32_t a, uint32_t b) -{ - uint32_t sum; - sum = do_usad(a, b); - sum += do_usad(a >> 8, b >> 8); - sum += do_usad(a >> 16, b >>16); - sum += do_usad(a >> 24, b >> 24); - return sum; -} - -/* For ARMv6 SEL instruction. */ -uint32_t HELPER(sel_flags)(uint32_t flags, uint32_t a, uint32_t b) -{ - uint32_t mask; - - mask = 0; - if (flags & 1) - mask |= 0xff; - if (flags & 2) - mask |= 0xff00; - if (flags & 4) - mask |= 0xff0000; - if (flags & 8) - mask |= 0xff000000; - return (a & mask) | (b & ~mask); -} - -uint32_t HELPER(logicq_cc)(uint64_t val) -{ - return (val >> 32) | (val != 0); -} - -/* VFP support. We follow the convention used for VFP instrunctions: - Single precition routines have a "s" suffix, double precision a - "d" suffix. */ - -/* Convert host exception flags to vfp form. */ -static inline int vfp_exceptbits_from_host(int host_bits) -{ - int target_bits = 0; - - if (host_bits & float_flag_invalid) - target_bits |= 1; - if (host_bits & float_flag_divbyzero) - target_bits |= 2; - if (host_bits & float_flag_overflow) - target_bits |= 4; - if (host_bits & float_flag_underflow) - target_bits |= 8; - if (host_bits & float_flag_inexact) - target_bits |= 0x10; - return target_bits; -} - -uint32_t HELPER(vfp_get_fpscr)(CPUState *env) -{ - int i; - uint32_t fpscr; - - fpscr = (env->vfp.xregs[ARM_VFP_FPSCR] & 0xffc8ffff) - | (env->vfp.vec_len << 16) - | (env->vfp.vec_stride << 20); - i = get_float_exception_flags(&env->vfp.fp_status); - fpscr |= vfp_exceptbits_from_host(i); - return fpscr; -} - -/* Convert vfp exception flags to target form. */ -static inline int vfp_exceptbits_to_host(int target_bits) -{ - int host_bits = 0; - - if (target_bits & 1) - host_bits |= float_flag_invalid; - if (target_bits & 2) - host_bits |= float_flag_divbyzero; - if (target_bits & 4) - host_bits |= float_flag_overflow; - if (target_bits & 8) - host_bits |= float_flag_underflow; - if (target_bits & 0x10) - host_bits |= float_flag_inexact; - return host_bits; -} - -void HELPER(vfp_set_fpscr)(CPUState *env, uint32_t val) -{ - int i; - uint32_t changed; - - changed = env->vfp.xregs[ARM_VFP_FPSCR]; - env->vfp.xregs[ARM_VFP_FPSCR] = (val & 0xffc8ffff); - env->vfp.vec_len = (val >> 16) & 7; - env->vfp.vec_stride = (val >> 20) & 3; - - changed ^= val; - if (changed & (3 << 22)) { - i = (val >> 22) & 3; - switch (i) { - case 0: - i = float_round_nearest_even; - break; - case 1: - i = float_round_up; - break; - case 2: - i = float_round_down; - break; - case 3: - i = float_round_to_zero; - break; - } - set_float_rounding_mode(i, &env->vfp.fp_status); - } - if (changed & (1 << 24)) - set_flush_to_zero((val & (1 << 24)) != 0, &env->vfp.fp_status); - if (changed & (1 << 25)) - set_default_nan_mode((val & (1 << 25)) != 0, &env->vfp.fp_status); - - i = vfp_exceptbits_to_host((val >> 8) & 0x1f); - set_float_exception_flags(i, &env->vfp.fp_status); -} - -#define VFP_HELPER(name, p) HELPER(glue(glue(vfp_,name),p)) - -#define VFP_BINOP(name) \ -float32 VFP_HELPER(name, s)(float32 a, float32 b, CPUState *env) \ -{ \ - return float32_ ## name (a, b, &env->vfp.fp_status); \ -} \ -float64 VFP_HELPER(name, d)(float64 a, float64 b, CPUState *env) \ -{ \ - return float64_ ## name (a, b, &env->vfp.fp_status); \ -} -VFP_BINOP(add) -VFP_BINOP(sub) -VFP_BINOP(mul) -VFP_BINOP(div) -#undef VFP_BINOP - -float32 VFP_HELPER(neg, s)(float32 a) -{ - return float32_chs(a); -} - -float64 VFP_HELPER(neg, d)(float64 a) -{ - return float64_chs(a); -} - -float32 VFP_HELPER(abs, s)(float32 a) -{ - return float32_abs(a); -} - -float64 VFP_HELPER(abs, d)(float64 a) -{ - return float64_abs(a); -} - -float32 VFP_HELPER(sqrt, s)(float32 a, CPUState *env) -{ - return float32_sqrt(a, &env->vfp.fp_status); -} - -float64 VFP_HELPER(sqrt, d)(float64 a, CPUState *env) -{ - return float64_sqrt(a, &env->vfp.fp_status); -} - -/* XXX: check quiet/signaling case */ -#define DO_VFP_cmp(p, type) \ -void VFP_HELPER(cmp, p)(type a, type b, CPUState *env) \ -{ \ - uint32_t flags; \ - switch(type ## _compare_quiet(a, b, &env->vfp.fp_status)) { \ - case 0: flags = 0x6; break; \ - case -1: flags = 0x8; break; \ - case 1: flags = 0x2; break; \ - default: case 2: flags = 0x3; break; \ - } \ - env->vfp.xregs[ARM_VFP_FPSCR] = (flags << 28) \ - | (env->vfp.xregs[ARM_VFP_FPSCR] & 0x0fffffff); \ -} \ -void VFP_HELPER(cmpe, p)(type a, type b, CPUState *env) \ -{ \ - uint32_t flags; \ - switch(type ## _compare(a, b, &env->vfp.fp_status)) { \ - case 0: flags = 0x6; break; \ - case -1: flags = 0x8; break; \ - case 1: flags = 0x2; break; \ - default: case 2: flags = 0x3; break; \ - } \ - env->vfp.xregs[ARM_VFP_FPSCR] = (flags << 28) \ - | (env->vfp.xregs[ARM_VFP_FPSCR] & 0x0fffffff); \ -} -DO_VFP_cmp(s, float32) -DO_VFP_cmp(d, float64) -#undef DO_VFP_cmp - -/* Helper routines to perform bitwise copies between float and int. */ -static inline float32 vfp_itos(uint32_t i) -{ - union { - uint32_t i; - float32 s; - } v; - - v.i = i; - return v.s; -} - -static inline uint32_t vfp_stoi(float32 s) -{ - union { - uint32_t i; - float32 s; - } v; - - v.s = s; - return v.i; -} - -static inline float64 vfp_itod(uint64_t i) -{ - union { - uint64_t i; - float64 d; - } v; - - v.i = i; - return v.d; -} - -static inline uint64_t vfp_dtoi(float64 d) -{ - union { - uint64_t i; - float64 d; - } v; - - v.d = d; - return v.i; -} - -/* Integer to float conversion. */ -float32 VFP_HELPER(uito, s)(float32 x, CPUState *env) -{ - return uint32_to_float32(vfp_stoi(x), &env->vfp.fp_status); -} - -float64 VFP_HELPER(uito, d)(float32 x, CPUState *env) -{ - return uint32_to_float64(vfp_stoi(x), &env->vfp.fp_status); -} - -float32 VFP_HELPER(sito, s)(float32 x, CPUState *env) -{ - return int32_to_float32(vfp_stoi(x), &env->vfp.fp_status); -} - -float64 VFP_HELPER(sito, d)(float32 x, CPUState *env) -{ - return int32_to_float64(vfp_stoi(x), &env->vfp.fp_status); -} - -/* Float to integer conversion. */ -float32 VFP_HELPER(toui, s)(float32 x, CPUState *env) -{ - return vfp_itos(float32_to_uint32(x, &env->vfp.fp_status)); -} - -float32 VFP_HELPER(toui, d)(float64 x, CPUState *env) -{ - return vfp_itos(float64_to_uint32(x, &env->vfp.fp_status)); -} - -float32 VFP_HELPER(tosi, s)(float32 x, CPUState *env) -{ - return vfp_itos(float32_to_int32(x, &env->vfp.fp_status)); -} - -float32 VFP_HELPER(tosi, d)(float64 x, CPUState *env) -{ - return vfp_itos(float64_to_int32(x, &env->vfp.fp_status)); -} - -float32 VFP_HELPER(touiz, s)(float32 x, CPUState *env) -{ - return vfp_itos(float32_to_uint32_round_to_zero(x, &env->vfp.fp_status)); -} - -float32 VFP_HELPER(touiz, d)(float64 x, CPUState *env) -{ - return vfp_itos(float64_to_uint32_round_to_zero(x, &env->vfp.fp_status)); -} - -float32 VFP_HELPER(tosiz, s)(float32 x, CPUState *env) -{ - return vfp_itos(float32_to_int32_round_to_zero(x, &env->vfp.fp_status)); -} - -float32 VFP_HELPER(tosiz, d)(float64 x, CPUState *env) -{ - return vfp_itos(float64_to_int32_round_to_zero(x, &env->vfp.fp_status)); -} - -/* floating point conversion */ -float64 VFP_HELPER(fcvtd, s)(float32 x, CPUState *env) -{ - return float32_to_float64(x, &env->vfp.fp_status); -} - -float32 VFP_HELPER(fcvts, d)(float64 x, CPUState *env) -{ - return float64_to_float32(x, &env->vfp.fp_status); -} - -/* VFP3 fixed point conversion. */ -#define VFP_CONV_FIX(name, p, ftype, itype, sign) \ -ftype VFP_HELPER(name##to, p)(ftype x, uint32_t shift, CPUState *env) \ -{ \ - ftype tmp; \ - tmp = sign##int32_to_##ftype ((itype)vfp_##p##toi(x), \ - &env->vfp.fp_status); \ - return ftype##_scalbn(tmp, -(int)shift, &env->vfp.fp_status); \ -} \ -ftype VFP_HELPER(to##name, p)(ftype x, uint32_t shift, CPUState *env) \ -{ \ - ftype tmp; \ - tmp = ftype##_scalbn(x, shift, &env->vfp.fp_status); \ - return vfp_ito##p((itype)ftype##_to_##sign##int32_round_to_zero(tmp, \ - &env->vfp.fp_status)); \ -} - -VFP_CONV_FIX(sh, d, float64, int16, ) -VFP_CONV_FIX(sl, d, float64, int32, ) -VFP_CONV_FIX(uh, d, float64, uint16, u) -VFP_CONV_FIX(ul, d, float64, uint32, u) -VFP_CONV_FIX(sh, s, float32, int16, ) -VFP_CONV_FIX(sl, s, float32, int32, ) -VFP_CONV_FIX(uh, s, float32, uint16, u) -VFP_CONV_FIX(ul, s, float32, uint32, u) -#undef VFP_CONV_FIX - -/* Half precision conversions. */ -float32 HELPER(vfp_fcvt_f16_to_f32)(uint32_t a, CPUState *env) -{ - float_status *s = &env->vfp.fp_status; - int ieee = (env->vfp.xregs[ARM_VFP_FPSCR] & (1 << 26)) == 0; - return float16_to_float32(a, ieee, s); -} - -uint32_t HELPER(vfp_fcvt_f32_to_f16)(float32 a, CPUState *env) -{ - float_status *s = &env->vfp.fp_status; - int ieee = (env->vfp.xregs[ARM_VFP_FPSCR] & (1 << 26)) == 0; - return float32_to_float16(a, ieee, s); -} - -float32 HELPER(recps_f32)(float32 a, float32 b, CPUState *env) -{ - float_status *s = &env->vfp.fp_status; - float32 two = int32_to_float32(2, s); - return float32_sub(two, float32_mul(a, b, s), s); -} - -float32 HELPER(rsqrts_f32)(float32 a, float32 b, CPUState *env) -{ - float_status *s = &env->vfp.fp_status; - float32 three = int32_to_float32(3, s); - return float32_sub(three, float32_mul(a, b, s), s); -} - -/* NEON helpers. */ - -/* TODO: The architecture specifies the value that the estimate functions - should return. We return the exact reciprocal/root instead. */ -float32 HELPER(recpe_f32)(float32 a, CPUState *env) -{ - float_status *s = &env->vfp.fp_status; - float32 one = int32_to_float32(1, s); - return float32_div(one, a, s); -} - -float32 HELPER(rsqrte_f32)(float32 a, CPUState *env) -{ - float_status *s = &env->vfp.fp_status; - float32 one = int32_to_float32(1, s); - return float32_div(one, float32_sqrt(a, s), s); -} - -uint32_t HELPER(recpe_u32)(uint32_t a, CPUState *env) -{ - float_status *s = &env->vfp.fp_status; - float32 tmp; - tmp = int32_to_float32(a, s); - tmp = float32_scalbn(tmp, -32, s); - tmp = helper_recpe_f32(tmp, env); - tmp = float32_scalbn(tmp, 31, s); - return float32_to_int32(tmp, s); -} - -uint32_t HELPER(rsqrte_u32)(uint32_t a, CPUState *env) -{ - float_status *s = &env->vfp.fp_status; - float32 tmp; - tmp = int32_to_float32(a, s); - tmp = float32_scalbn(tmp, -32, s); - tmp = helper_rsqrte_f32(tmp, env); - tmp = float32_scalbn(tmp, 31, s); - return float32_to_int32(tmp, s); -} - -void HELPER(set_teecr)(CPUState *env, uint32_t val) -{ - val &= 1; - if (env->teecr != val) { - env->teecr = val; - tb_flush(env); - } -} diff --git a/qemu/qemu-git/target-arm/.svn/text-base/helpers.h.svn-base b/qemu/qemu-git/target-arm/.svn/text-base/helpers.h.svn-base deleted file mode 100644 index 0d1bc47..0000000 --- a/qemu/qemu-git/target-arm/.svn/text-base/helpers.h.svn-base +++ /dev/null @@ -1,450 +0,0 @@ -#include "def-helper.h" - -DEF_HELPER_1(clz, i32, i32) -DEF_HELPER_1(sxtb16, i32, i32) -DEF_HELPER_1(uxtb16, i32, i32) - -DEF_HELPER_2(add_setq, i32, i32, i32) -DEF_HELPER_2(add_saturate, i32, i32, i32) -DEF_HELPER_2(sub_saturate, i32, i32, i32) -DEF_HELPER_2(add_usaturate, i32, i32, i32) -DEF_HELPER_2(sub_usaturate, i32, i32, i32) -DEF_HELPER_1(double_saturate, i32, s32) -DEF_HELPER_2(sdiv, s32, s32, s32) -DEF_HELPER_2(udiv, i32, i32, i32) -DEF_HELPER_1(rbit, i32, i32) -DEF_HELPER_1(abs, i32, i32) - -#define PAS_OP(pfx) \ - DEF_HELPER_3(pfx ## add8, i32, i32, i32, ptr) \ - DEF_HELPER_3(pfx ## sub8, i32, i32, i32, ptr) \ - DEF_HELPER_3(pfx ## sub16, i32, i32, i32, ptr) \ - DEF_HELPER_3(pfx ## add16, i32, i32, i32, ptr) \ - DEF_HELPER_3(pfx ## addsubx, i32, i32, i32, ptr) \ - DEF_HELPER_3(pfx ## subaddx, i32, i32, i32, ptr) - -PAS_OP(s) -PAS_OP(u) -#undef PAS_OP - -#define PAS_OP(pfx) \ - DEF_HELPER_2(pfx ## add8, i32, i32, i32) \ - DEF_HELPER_2(pfx ## sub8, i32, i32, i32) \ - DEF_HELPER_2(pfx ## sub16, i32, i32, i32) \ - DEF_HELPER_2(pfx ## add16, i32, i32, i32) \ - DEF_HELPER_2(pfx ## addsubx, i32, i32, i32) \ - DEF_HELPER_2(pfx ## subaddx, i32, i32, i32) -PAS_OP(q) -PAS_OP(sh) -PAS_OP(uq) -PAS_OP(uh) -#undef PAS_OP - -DEF_HELPER_2(ssat, i32, i32, i32) -DEF_HELPER_2(usat, i32, i32, i32) -DEF_HELPER_2(ssat16, i32, i32, i32) -DEF_HELPER_2(usat16, i32, i32, i32) - -DEF_HELPER_2(usad8, i32, i32, i32) - -DEF_HELPER_1(logicq_cc, i32, i64) - -DEF_HELPER_3(sel_flags, i32, i32, i32, i32) -DEF_HELPER_1(exception, void, i32) -DEF_HELPER_0(wfi, void) - -DEF_HELPER_2(cpsr_write, void, i32, i32) -DEF_HELPER_0(cpsr_read, i32) - -DEF_HELPER_3(v7m_msr, void, env, i32, i32) -DEF_HELPER_2(v7m_mrs, i32, env, i32) - -DEF_HELPER_3(set_cp15, void, env, i32, i32) -DEF_HELPER_2(get_cp15, i32, env, i32) - -DEF_HELPER_3(set_cp, void, env, i32, i32) -DEF_HELPER_2(get_cp, i32, env, i32) - -DEF_HELPER_2(get_r13_banked, i32, env, i32) -DEF_HELPER_3(set_r13_banked, void, env, i32, i32) - -DEF_HELPER_1(get_user_reg, i32, i32) -DEF_HELPER_2(set_user_reg, void, i32, i32) - -DEF_HELPER_1(vfp_get_fpscr, i32, env) -DEF_HELPER_2(vfp_set_fpscr, void, env, i32) - -DEF_HELPER_3(vfp_adds, f32, f32, f32, env) -DEF_HELPER_3(vfp_addd, f64, f64, f64, env) -DEF_HELPER_3(vfp_subs, f32, f32, f32, env) -DEF_HELPER_3(vfp_subd, f64, f64, f64, env) -DEF_HELPER_3(vfp_muls, f32, f32, f32, env) -DEF_HELPER_3(vfp_muld, f64, f64, f64, env) -DEF_HELPER_3(vfp_divs, f32, f32, f32, env) -DEF_HELPER_3(vfp_divd, f64, f64, f64, env) -DEF_HELPER_1(vfp_negs, f32, f32) -DEF_HELPER_1(vfp_negd, f64, f64) -DEF_HELPER_1(vfp_abss, f32, f32) -DEF_HELPER_1(vfp_absd, f64, f64) -DEF_HELPER_2(vfp_sqrts, f32, f32, env) -DEF_HELPER_2(vfp_sqrtd, f64, f64, env) -DEF_HELPER_3(vfp_cmps, void, f32, f32, env) -DEF_HELPER_3(vfp_cmpd, void, f64, f64, env) -DEF_HELPER_3(vfp_cmpes, void, f32, f32, env) -DEF_HELPER_3(vfp_cmped, void, f64, f64, env) - -DEF_HELPER_2(vfp_fcvtds, f64, f32, env) -DEF_HELPER_2(vfp_fcvtsd, f32, f64, env) - -DEF_HELPER_2(vfp_uitos, f32, f32, env) -DEF_HELPER_2(vfp_uitod, f64, f32, env) -DEF_HELPER_2(vfp_sitos, f32, f32, env) -DEF_HELPER_2(vfp_sitod, f64, f32, env) - -DEF_HELPER_2(vfp_touis, f32, f32, env) -DEF_HELPER_2(vfp_touid, f32, f64, env) -DEF_HELPER_2(vfp_touizs, f32, f32, env) -DEF_HELPER_2(vfp_touizd, f32, f64, env) -DEF_HELPER_2(vfp_tosis, f32, f32, env) -DEF_HELPER_2(vfp_tosid, f32, f64, env) -DEF_HELPER_2(vfp_tosizs, f32, f32, env) -DEF_HELPER_2(vfp_tosizd, f32, f64, env) - -DEF_HELPER_3(vfp_toshs, f32, f32, i32, env) -DEF_HELPER_3(vfp_tosls, f32, f32, i32, env) -DEF_HELPER_3(vfp_touhs, f32, f32, i32, env) -DEF_HELPER_3(vfp_touls, f32, f32, i32, env) -DEF_HELPER_3(vfp_toshd, f64, f64, i32, env) -DEF_HELPER_3(vfp_tosld, f64, f64, i32, env) -DEF_HELPER_3(vfp_touhd, f64, f64, i32, env) -DEF_HELPER_3(vfp_tould, f64, f64, i32, env) -DEF_HELPER_3(vfp_shtos, f32, f32, i32, env) -DEF_HELPER_3(vfp_sltos, f32, f32, i32, env) -DEF_HELPER_3(vfp_uhtos, f32, f32, i32, env) -DEF_HELPER_3(vfp_ultos, f32, f32, i32, env) -DEF_HELPER_3(vfp_shtod, f64, f64, i32, env) -DEF_HELPER_3(vfp_sltod, f64, f64, i32, env) -DEF_HELPER_3(vfp_uhtod, f64, f64, i32, env) -DEF_HELPER_3(vfp_ultod, f64, f64, i32, env) - -DEF_HELPER_2(vfp_fcvt_f16_to_f32, f32, i32, env) -DEF_HELPER_2(vfp_fcvt_f32_to_f16, i32, f32, env) - -DEF_HELPER_3(recps_f32, f32, f32, f32, env) -DEF_HELPER_3(rsqrts_f32, f32, f32, f32, env) -DEF_HELPER_2(recpe_f32, f32, f32, env) -DEF_HELPER_2(rsqrte_f32, f32, f32, env) -DEF_HELPER_2(recpe_u32, i32, i32, env) -DEF_HELPER_2(rsqrte_u32, i32, i32, env) -DEF_HELPER_4(neon_tbl, i32, i32, i32, i32, i32) -DEF_HELPER_2(neon_add_saturate_u64, i64, i64, i64) -DEF_HELPER_2(neon_add_saturate_s64, i64, i64, i64) -DEF_HELPER_2(neon_sub_saturate_u64, i64, i64, i64) -DEF_HELPER_2(neon_sub_saturate_s64, i64, i64, i64) - -DEF_HELPER_2(add_cc, i32, i32, i32) -DEF_HELPER_2(adc_cc, i32, i32, i32) -DEF_HELPER_2(sub_cc, i32, i32, i32) -DEF_HELPER_2(sbc_cc, i32, i32, i32) - -DEF_HELPER_2(shl, i32, i32, i32) -DEF_HELPER_2(shr, i32, i32, i32) -DEF_HELPER_2(sar, i32, i32, i32) -DEF_HELPER_2(shl_cc, i32, i32, i32) -DEF_HELPER_2(shr_cc, i32, i32, i32) -DEF_HELPER_2(sar_cc, i32, i32, i32) -DEF_HELPER_2(ror_cc, i32, i32, i32) - -/* neon_helper.c */ -DEF_HELPER_3(neon_qadd_u8, i32, env, i32, i32) -DEF_HELPER_3(neon_qadd_s8, i32, env, i32, i32) -DEF_HELPER_3(neon_qadd_u16, i32, env, i32, i32) -DEF_HELPER_3(neon_qadd_s16, i32, env, i32, i32) -DEF_HELPER_3(neon_qsub_u8, i32, env, i32, i32) -DEF_HELPER_3(neon_qsub_s8, i32, env, i32, i32) -DEF_HELPER_3(neon_qsub_u16, i32, env, i32, i32) -DEF_HELPER_3(neon_qsub_s16, i32, env, i32, i32) - -DEF_HELPER_2(neon_hadd_s8, i32, i32, i32) -DEF_HELPER_2(neon_hadd_u8, i32, i32, i32) -DEF_HELPER_2(neon_hadd_s16, i32, i32, i32) -DEF_HELPER_2(neon_hadd_u16, i32, i32, i32) -DEF_HELPER_2(neon_hadd_s32, s32, s32, s32) -DEF_HELPER_2(neon_hadd_u32, i32, i32, i32) -DEF_HELPER_2(neon_rhadd_s8, i32, i32, i32) -DEF_HELPER_2(neon_rhadd_u8, i32, i32, i32) -DEF_HELPER_2(neon_rhadd_s16, i32, i32, i32) -DEF_HELPER_2(neon_rhadd_u16, i32, i32, i32) -DEF_HELPER_2(neon_rhadd_s32, s32, s32, s32) -DEF_HELPER_2(neon_rhadd_u32, i32, i32, i32) -DEF_HELPER_2(neon_hsub_s8, i32, i32, i32) -DEF_HELPER_2(neon_hsub_u8, i32, i32, i32) -DEF_HELPER_2(neon_hsub_s16, i32, i32, i32) -DEF_HELPER_2(neon_hsub_u16, i32, i32, i32) -DEF_HELPER_2(neon_hsub_s32, s32, s32, s32) -DEF_HELPER_2(neon_hsub_u32, i32, i32, i32) - -DEF_HELPER_2(neon_cgt_u8, i32, i32, i32) -DEF_HELPER_2(neon_cgt_s8, i32, i32, i32) -DEF_HELPER_2(neon_cgt_u16, i32, i32, i32) -DEF_HELPER_2(neon_cgt_s16, i32, i32, i32) -DEF_HELPER_2(neon_cgt_u32, i32, i32, i32) -DEF_HELPER_2(neon_cgt_s32, i32, i32, i32) -DEF_HELPER_2(neon_cge_u8, i32, i32, i32) -DEF_HELPER_2(neon_cge_s8, i32, i32, i32) -DEF_HELPER_2(neon_cge_u16, i32, i32, i32) -DEF_HELPER_2(neon_cge_s16, i32, i32, i32) -DEF_HELPER_2(neon_cge_u32, i32, i32, i32) -DEF_HELPER_2(neon_cge_s32, i32, i32, i32) - -DEF_HELPER_2(neon_min_u8, i32, i32, i32) -DEF_HELPER_2(neon_min_s8, i32, i32, i32) -DEF_HELPER_2(neon_min_u16, i32, i32, i32) -DEF_HELPER_2(neon_min_s16, i32, i32, i32) -DEF_HELPER_2(neon_min_u32, i32, i32, i32) -DEF_HELPER_2(neon_min_s32, i32, i32, i32) -DEF_HELPER_2(neon_max_u8, i32, i32, i32) -DEF_HELPER_2(neon_max_s8, i32, i32, i32) -DEF_HELPER_2(neon_max_u16, i32, i32, i32) -DEF_HELPER_2(neon_max_s16, i32, i32, i32) -DEF_HELPER_2(neon_max_u32, i32, i32, i32) -DEF_HELPER_2(neon_max_s32, i32, i32, i32) -DEF_HELPER_2(neon_pmin_u8, i32, i32, i32) -DEF_HELPER_2(neon_pmin_s8, i32, i32, i32) -DEF_HELPER_2(neon_pmin_u16, i32, i32, i32) -DEF_HELPER_2(neon_pmin_s16, i32, i32, i32) -DEF_HELPER_2(neon_pmax_u8, i32, i32, i32) -DEF_HELPER_2(neon_pmax_s8, i32, i32, i32) -DEF_HELPER_2(neon_pmax_u16, i32, i32, i32) -DEF_HELPER_2(neon_pmax_s16, i32, i32, i32) - -DEF_HELPER_2(neon_abd_u8, i32, i32, i32) -DEF_HELPER_2(neon_abd_s8, i32, i32, i32) -DEF_HELPER_2(neon_abd_u16, i32, i32, i32) -DEF_HELPER_2(neon_abd_s16, i32, i32, i32) -DEF_HELPER_2(neon_abd_u32, i32, i32, i32) -DEF_HELPER_2(neon_abd_s32, i32, i32, i32) - -DEF_HELPER_2(neon_shl_u8, i32, i32, i32) -DEF_HELPER_2(neon_shl_s8, i32, i32, i32) -DEF_HELPER_2(neon_shl_u16, i32, i32, i32) -DEF_HELPER_2(neon_shl_s16, i32, i32, i32) -DEF_HELPER_2(neon_shl_u32, i32, i32, i32) -DEF_HELPER_2(neon_shl_s32, i32, i32, i32) -DEF_HELPER_2(neon_shl_u64, i64, i64, i64) -DEF_HELPER_2(neon_shl_s64, i64, i64, i64) -DEF_HELPER_2(neon_rshl_u8, i32, i32, i32) -DEF_HELPER_2(neon_rshl_s8, i32, i32, i32) -DEF_HELPER_2(neon_rshl_u16, i32, i32, i32) -DEF_HELPER_2(neon_rshl_s16, i32, i32, i32) -DEF_HELPER_2(neon_rshl_u32, i32, i32, i32) -DEF_HELPER_2(neon_rshl_s32, i32, i32, i32) -DEF_HELPER_2(neon_rshl_u64, i64, i64, i64) -DEF_HELPER_2(neon_rshl_s64, i64, i64, i64) -DEF_HELPER_3(neon_qshl_u8, i32, env, i32, i32) -DEF_HELPER_3(neon_qshl_s8, i32, env, i32, i32) -DEF_HELPER_3(neon_qshl_u16, i32, env, i32, i32) -DEF_HELPER_3(neon_qshl_s16, i32, env, i32, i32) -DEF_HELPER_3(neon_qshl_u32, i32, env, i32, i32) -DEF_HELPER_3(neon_qshl_s32, i32, env, i32, i32) -DEF_HELPER_3(neon_qshl_u64, i64, env, i64, i64) -DEF_HELPER_3(neon_qshl_s64, i64, env, i64, i64) -DEF_HELPER_3(neon_qrshl_u8, i32, env, i32, i32) -DEF_HELPER_3(neon_qrshl_s8, i32, env, i32, i32) -DEF_HELPER_3(neon_qrshl_u16, i32, env, i32, i32) -DEF_HELPER_3(neon_qrshl_s16, i32, env, i32, i32) -DEF_HELPER_3(neon_qrshl_u32, i32, env, i32, i32) -DEF_HELPER_3(neon_qrshl_s32, i32, env, i32, i32) -DEF_HELPER_3(neon_qrshl_u64, i64, env, i64, i64) -DEF_HELPER_3(neon_qrshl_s64, i64, env, i64, i64) - -DEF_HELPER_2(neon_add_u8, i32, i32, i32) -DEF_HELPER_2(neon_add_u16, i32, i32, i32) -DEF_HELPER_2(neon_padd_u8, i32, i32, i32) -DEF_HELPER_2(neon_padd_u16, i32, i32, i32) -DEF_HELPER_2(neon_sub_u8, i32, i32, i32) -DEF_HELPER_2(neon_sub_u16, i32, i32, i32) -DEF_HELPER_2(neon_mul_u8, i32, i32, i32) -DEF_HELPER_2(neon_mul_u16, i32, i32, i32) -DEF_HELPER_2(neon_mul_p8, i32, i32, i32) - -DEF_HELPER_2(neon_tst_u8, i32, i32, i32) -DEF_HELPER_2(neon_tst_u16, i32, i32, i32) -DEF_HELPER_2(neon_tst_u32, i32, i32, i32) -DEF_HELPER_2(neon_ceq_u8, i32, i32, i32) -DEF_HELPER_2(neon_ceq_u16, i32, i32, i32) -DEF_HELPER_2(neon_ceq_u32, i32, i32, i32) - -DEF_HELPER_1(neon_abs_s8, i32, i32) -DEF_HELPER_1(neon_abs_s16, i32, i32) -DEF_HELPER_1(neon_clz_u8, i32, i32) -DEF_HELPER_1(neon_clz_u16, i32, i32) -DEF_HELPER_1(neon_cls_s8, i32, i32) -DEF_HELPER_1(neon_cls_s16, i32, i32) -DEF_HELPER_1(neon_cls_s32, i32, i32) -DEF_HELPER_1(neon_cnt_u8, i32, i32) - -DEF_HELPER_3(neon_qdmulh_s16, i32, env, i32, i32) -DEF_HELPER_3(neon_qrdmulh_s16, i32, env, i32, i32) -DEF_HELPER_3(neon_qdmulh_s32, i32, env, i32, i32) -DEF_HELPER_3(neon_qrdmulh_s32, i32, env, i32, i32) - -DEF_HELPER_1(neon_narrow_u8, i32, i64) -DEF_HELPER_1(neon_narrow_u16, i32, i64) -DEF_HELPER_2(neon_narrow_sat_u8, i32, env, i64) -DEF_HELPER_2(neon_narrow_sat_s8, i32, env, i64) -DEF_HELPER_2(neon_narrow_sat_u16, i32, env, i64) -DEF_HELPER_2(neon_narrow_sat_s16, i32, env, i64) -DEF_HELPER_2(neon_narrow_sat_u32, i32, env, i64) -DEF_HELPER_2(neon_narrow_sat_s32, i32, env, i64) -DEF_HELPER_1(neon_narrow_high_u8, i32, i64) -DEF_HELPER_1(neon_narrow_high_u16, i32, i64) -DEF_HELPER_1(neon_narrow_round_high_u8, i32, i64) -DEF_HELPER_1(neon_narrow_round_high_u16, i32, i64) -DEF_HELPER_1(neon_widen_u8, i64, i32) -DEF_HELPER_1(neon_widen_s8, i64, i32) -DEF_HELPER_1(neon_widen_u16, i64, i32) -DEF_HELPER_1(neon_widen_s16, i64, i32) - -DEF_HELPER_2(neon_addl_u16, i64, i64, i64) -DEF_HELPER_2(neon_addl_u32, i64, i64, i64) -DEF_HELPER_2(neon_paddl_u16, i64, i64, i64) -DEF_HELPER_2(neon_paddl_u32, i64, i64, i64) -DEF_HELPER_2(neon_subl_u16, i64, i64, i64) -DEF_HELPER_2(neon_subl_u32, i64, i64, i64) -DEF_HELPER_3(neon_addl_saturate_s32, i64, env, i64, i64) -DEF_HELPER_3(neon_addl_saturate_s64, i64, env, i64, i64) -DEF_HELPER_2(neon_abdl_u16, i64, i32, i32) -DEF_HELPER_2(neon_abdl_s16, i64, i32, i32) -DEF_HELPER_2(neon_abdl_u32, i64, i32, i32) -DEF_HELPER_2(neon_abdl_s32, i64, i32, i32) -DEF_HELPER_2(neon_abdl_u64, i64, i32, i32) -DEF_HELPER_2(neon_abdl_s64, i64, i32, i32) -DEF_HELPER_2(neon_mull_u8, i64, i32, i32) -DEF_HELPER_2(neon_mull_s8, i64, i32, i32) -DEF_HELPER_2(neon_mull_u16, i64, i32, i32) -DEF_HELPER_2(neon_mull_s16, i64, i32, i32) - -DEF_HELPER_1(neon_negl_u16, i64, i64) -DEF_HELPER_1(neon_negl_u32, i64, i64) -DEF_HELPER_1(neon_negl_u64, i64, i64) - -DEF_HELPER_2(neon_qabs_s8, i32, env, i32) -DEF_HELPER_2(neon_qabs_s16, i32, env, i32) -DEF_HELPER_2(neon_qabs_s32, i32, env, i32) -DEF_HELPER_2(neon_qneg_s8, i32, env, i32) -DEF_HELPER_2(neon_qneg_s16, i32, env, i32) -DEF_HELPER_2(neon_qneg_s32, i32, env, i32) - -DEF_HELPER_2(neon_min_f32, i32, i32, i32) -DEF_HELPER_2(neon_max_f32, i32, i32, i32) -DEF_HELPER_2(neon_abd_f32, i32, i32, i32) -DEF_HELPER_2(neon_add_f32, i32, i32, i32) -DEF_HELPER_2(neon_sub_f32, i32, i32, i32) -DEF_HELPER_2(neon_mul_f32, i32, i32, i32) -DEF_HELPER_2(neon_ceq_f32, i32, i32, i32) -DEF_HELPER_2(neon_cge_f32, i32, i32, i32) -DEF_HELPER_2(neon_cgt_f32, i32, i32, i32) -DEF_HELPER_2(neon_acge_f32, i32, i32, i32) -DEF_HELPER_2(neon_acgt_f32, i32, i32, i32) - -/* iwmmxt_helper.c */ -DEF_HELPER_2(iwmmxt_maddsq, i64, i64, i64) -DEF_HELPER_2(iwmmxt_madduq, i64, i64, i64) -DEF_HELPER_2(iwmmxt_sadb, i64, i64, i64) -DEF_HELPER_2(iwmmxt_sadw, i64, i64, i64) -DEF_HELPER_2(iwmmxt_mulslw, i64, i64, i64) -DEF_HELPER_2(iwmmxt_mulshw, i64, i64, i64) -DEF_HELPER_2(iwmmxt_mululw, i64, i64, i64) -DEF_HELPER_2(iwmmxt_muluhw, i64, i64, i64) -DEF_HELPER_2(iwmmxt_macsw, i64, i64, i64) -DEF_HELPER_2(iwmmxt_macuw, i64, i64, i64) -DEF_HELPER_1(iwmmxt_setpsr_nz, i32, i64) - -#define DEF_IWMMXT_HELPER_SIZE_ENV(name) \ -DEF_HELPER_3(iwmmxt_##name##b, i64, env, i64, i64) \ -DEF_HELPER_3(iwmmxt_##name##w, i64, env, i64, i64) \ -DEF_HELPER_3(iwmmxt_##name##l, i64, env, i64, i64) \ - -DEF_IWMMXT_HELPER_SIZE_ENV(unpackl) -DEF_IWMMXT_HELPER_SIZE_ENV(unpackh) - -DEF_HELPER_2(iwmmxt_unpacklub, i64, env, i64) -DEF_HELPER_2(iwmmxt_unpackluw, i64, env, i64) -DEF_HELPER_2(iwmmxt_unpacklul, i64, env, i64) -DEF_HELPER_2(iwmmxt_unpackhub, i64, env, i64) -DEF_HELPER_2(iwmmxt_unpackhuw, i64, env, i64) -DEF_HELPER_2(iwmmxt_unpackhul, i64, env, i64) -DEF_HELPER_2(iwmmxt_unpacklsb, i64, env, i64) -DEF_HELPER_2(iwmmxt_unpacklsw, i64, env, i64) -DEF_HELPER_2(iwmmxt_unpacklsl, i64, env, i64) -DEF_HELPER_2(iwmmxt_unpackhsb, i64, env, i64) -DEF_HELPER_2(iwmmxt_unpackhsw, i64, env, i64) -DEF_HELPER_2(iwmmxt_unpackhsl, i64, env, i64) - -DEF_IWMMXT_HELPER_SIZE_ENV(cmpeq) -DEF_IWMMXT_HELPER_SIZE_ENV(cmpgtu) -DEF_IWMMXT_HELPER_SIZE_ENV(cmpgts) - -DEF_IWMMXT_HELPER_SIZE_ENV(mins) -DEF_IWMMXT_HELPER_SIZE_ENV(minu) -DEF_IWMMXT_HELPER_SIZE_ENV(maxs) -DEF_IWMMXT_HELPER_SIZE_ENV(maxu) - -DEF_IWMMXT_HELPER_SIZE_ENV(subn) -DEF_IWMMXT_HELPER_SIZE_ENV(addn) -DEF_IWMMXT_HELPER_SIZE_ENV(subu) -DEF_IWMMXT_HELPER_SIZE_ENV(addu) -DEF_IWMMXT_HELPER_SIZE_ENV(subs) -DEF_IWMMXT_HELPER_SIZE_ENV(adds) - -DEF_HELPER_3(iwmmxt_avgb0, i64, env, i64, i64) -DEF_HELPER_3(iwmmxt_avgb1, i64, env, i64, i64) -DEF_HELPER_3(iwmmxt_avgw0, i64, env, i64, i64) -DEF_HELPER_3(iwmmxt_avgw1, i64, env, i64, i64) - -DEF_HELPER_2(iwmmxt_msadb, i64, i64, i64) - -DEF_HELPER_3(iwmmxt_align, i64, i64, i64, i32) -DEF_HELPER_4(iwmmxt_insr, i64, i64, i32, i32, i32) - -DEF_HELPER_1(iwmmxt_bcstb, i64, i32) -DEF_HELPER_1(iwmmxt_bcstw, i64, i32) -DEF_HELPER_1(iwmmxt_bcstl, i64, i32) - -DEF_HELPER_1(iwmmxt_addcb, i64, i64) -DEF_HELPER_1(iwmmxt_addcw, i64, i64) -DEF_HELPER_1(iwmmxt_addcl, i64, i64) - -DEF_HELPER_1(iwmmxt_msbb, i32, i64) -DEF_HELPER_1(iwmmxt_msbw, i32, i64) -DEF_HELPER_1(iwmmxt_msbl, i32, i64) - -DEF_HELPER_3(iwmmxt_srlw, i64, env, i64, i32) -DEF_HELPER_3(iwmmxt_srll, i64, env, i64, i32) -DEF_HELPER_3(iwmmxt_srlq, i64, env, i64, i32) -DEF_HELPER_3(iwmmxt_sllw, i64, env, i64, i32) -DEF_HELPER_3(iwmmxt_slll, i64, env, i64, i32) -DEF_HELPER_3(iwmmxt_sllq, i64, env, i64, i32) -DEF_HELPER_3(iwmmxt_sraw, i64, env, i64, i32) -DEF_HELPER_3(iwmmxt_sral, i64, env, i64, i32) -DEF_HELPER_3(iwmmxt_sraq, i64, env, i64, i32) -DEF_HELPER_3(iwmmxt_rorw, i64, env, i64, i32) -DEF_HELPER_3(iwmmxt_rorl, i64, env, i64, i32) -DEF_HELPER_3(iwmmxt_rorq, i64, env, i64, i32) -DEF_HELPER_3(iwmmxt_shufh, i64, env, i64, i32) - -DEF_HELPER_3(iwmmxt_packuw, i64, env, i64, i64) -DEF_HELPER_3(iwmmxt_packul, i64, env, i64, i64) -DEF_HELPER_3(iwmmxt_packuq, i64, env, i64, i64) -DEF_HELPER_3(iwmmxt_packsw, i64, env, i64, i64) -DEF_HELPER_3(iwmmxt_packsl, i64, env, i64, i64) -DEF_HELPER_3(iwmmxt_packsq, i64, env, i64, i64) - -DEF_HELPER_3(iwmmxt_muladdsl, i64, i64, i32, i32) -DEF_HELPER_3(iwmmxt_muladdsw, i64, i64, i32, i32) -DEF_HELPER_3(iwmmxt_muladdswl, i64, i64, i32, i32) - -DEF_HELPER_2(set_teecr, void, env, i32) - -#include "def-helper.h" diff --git a/qemu/qemu-git/target-arm/.svn/text-base/iwmmxt_helper.c.svn-base b/qemu/qemu-git/target-arm/.svn/text-base/iwmmxt_helper.c.svn-base deleted file mode 100644 index 3332f70..0000000 --- a/qemu/qemu-git/target-arm/.svn/text-base/iwmmxt_helper.c.svn-base +++ /dev/null @@ -1,681 +0,0 @@ -/* - * iwMMXt micro operations for XScale. - * - * Copyright (c) 2007 OpenedHand, Ltd. - * Written by Andrzej Zaborowski - * Copyright (c) 2008 CodeSourcery - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library 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 - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, see . - */ - -#include -#include - -#include "cpu.h" -#include "exec-all.h" -#include "helpers.h" - -/* iwMMXt macros extracted from GNU gdb. */ - -/* Set the SIMD wCASF flags for 8, 16, 32 or 64-bit operations. */ -#define SIMD8_SET( v, n, b) ((v != 0) << ((((b) + 1) * 4) + (n))) -#define SIMD16_SET(v, n, h) ((v != 0) << ((((h) + 1) * 8) + (n))) -#define SIMD32_SET(v, n, w) ((v != 0) << ((((w) + 1) * 16) + (n))) -#define SIMD64_SET(v, n) ((v != 0) << (32 + (n))) -/* Flags to pass as "n" above. */ -#define SIMD_NBIT -1 -#define SIMD_ZBIT -2 -#define SIMD_CBIT -3 -#define SIMD_VBIT -4 -/* Various status bit macros. */ -#define NBIT8(x) ((x) & 0x80) -#define NBIT16(x) ((x) & 0x8000) -#define NBIT32(x) ((x) & 0x80000000) -#define NBIT64(x) ((x) & 0x8000000000000000ULL) -#define ZBIT8(x) (((x) & 0xff) == 0) -#define ZBIT16(x) (((x) & 0xffff) == 0) -#define ZBIT32(x) (((x) & 0xffffffff) == 0) -#define ZBIT64(x) (x == 0) -/* Sign extension macros. */ -#define EXTEND8H(a) ((uint16_t) (int8_t) (a)) -#define EXTEND8(a) ((uint32_t) (int8_t) (a)) -#define EXTEND16(a) ((uint32_t) (int16_t) (a)) -#define EXTEND16S(a) ((int32_t) (int16_t) (a)) -#define EXTEND32(a) ((uint64_t) (int32_t) (a)) - -uint64_t HELPER(iwmmxt_maddsq)(uint64_t a, uint64_t b) -{ - a = (( - EXTEND16S((a >> 0) & 0xffff) * EXTEND16S((b >> 0) & 0xffff) + - EXTEND16S((a >> 16) & 0xffff) * EXTEND16S((b >> 16) & 0xffff) - ) & 0xffffffff) | ((uint64_t) ( - EXTEND16S((a >> 32) & 0xffff) * EXTEND16S((b >> 32) & 0xffff) + - EXTEND16S((a >> 48) & 0xffff) * EXTEND16S((b >> 48) & 0xffff) - ) << 32); - return a; -} - -uint64_t HELPER(iwmmxt_madduq)(uint64_t a, uint64_t b) -{ - a = (( - ((a >> 0) & 0xffff) * ((b >> 0) & 0xffff) + - ((a >> 16) & 0xffff) * ((b >> 16) & 0xffff) - ) & 0xffffffff) | (( - ((a >> 32) & 0xffff) * ((b >> 32) & 0xffff) + - ((a >> 48) & 0xffff) * ((b >> 48) & 0xffff) - ) << 32); - return a; -} - -uint64_t HELPER(iwmmxt_sadb)(uint64_t a, uint64_t b) -{ -#define abs(x) (((x) >= 0) ? x : -x) -#define SADB(SHR) abs((int) ((a >> SHR) & 0xff) - (int) ((b >> SHR) & 0xff)) - return - SADB(0) + SADB(8) + SADB(16) + SADB(24) + - SADB(32) + SADB(40) + SADB(48) + SADB(56); -#undef SADB -} - -uint64_t HELPER(iwmmxt_sadw)(uint64_t a, uint64_t b) -{ -#define SADW(SHR) \ - abs((int) ((a >> SHR) & 0xffff) - (int) ((b >> SHR) & 0xffff)) - return SADW(0) + SADW(16) + SADW(32) + SADW(48); -#undef SADW -} - -uint64_t HELPER(iwmmxt_mulslw)(uint64_t a, uint64_t b) -{ -#define MULS(SHR) ((uint64_t) ((( \ - EXTEND16S((a >> SHR) & 0xffff) * EXTEND16S((b >> SHR) & 0xffff) \ - ) >> 0) & 0xffff) << SHR) - return MULS(0) | MULS(16) | MULS(32) | MULS(48); -#undef MULS -} - -uint64_t HELPER(iwmmxt_mulshw)(uint64_t a, uint64_t b) -{ -#define MULS(SHR) ((uint64_t) ((( \ - EXTEND16S((a >> SHR) & 0xffff) * EXTEND16S((b >> SHR) & 0xffff) \ - ) >> 16) & 0xffff) << SHR) - return MULS(0) | MULS(16) | MULS(32) | MULS(48); -#undef MULS -} - -uint64_t HELPER(iwmmxt_mululw)(uint64_t a, uint64_t b) -{ -#define MULU(SHR) ((uint64_t) ((( \ - ((a >> SHR) & 0xffff) * ((b >> SHR) & 0xffff) \ - ) >> 0) & 0xffff) << SHR) - return MULU(0) | MULU(16) | MULU(32) | MULU(48); -#undef MULU -} - -uint64_t HELPER(iwmmxt_muluhw)(uint64_t a, uint64_t b) -{ -#define MULU(SHR) ((uint64_t) ((( \ - ((a >> SHR) & 0xffff) * ((b >> SHR) & 0xffff) \ - ) >> 16) & 0xffff) << SHR) - return MULU(0) | MULU(16) | MULU(32) | MULU(48); -#undef MULU -} - -uint64_t HELPER(iwmmxt_macsw)(uint64_t a, uint64_t b) -{ -#define MACS(SHR) ( \ - EXTEND16((a >> SHR) & 0xffff) * EXTEND16S((b >> SHR) & 0xffff)) - return (int64_t) (MACS(0) + MACS(16) + MACS(32) + MACS(48)); -#undef MACS -} - -uint64_t HELPER(iwmmxt_macuw)(uint64_t a, uint64_t b) -{ -#define MACU(SHR) ( \ - (uint32_t) ((a >> SHR) & 0xffff) * \ - (uint32_t) ((b >> SHR) & 0xffff)) - return MACU(0) + MACU(16) + MACU(32) + MACU(48); -#undef MACU -} - -#define NZBIT8(x, i) \ - SIMD8_SET(NBIT8((x) & 0xff), SIMD_NBIT, i) | \ - SIMD8_SET(ZBIT8((x) & 0xff), SIMD_ZBIT, i) -#define NZBIT16(x, i) \ - SIMD16_SET(NBIT16((x) & 0xffff), SIMD_NBIT, i) | \ - SIMD16_SET(ZBIT16((x) & 0xffff), SIMD_ZBIT, i) -#define NZBIT32(x, i) \ - SIMD32_SET(NBIT32((x) & 0xffffffff), SIMD_NBIT, i) | \ - SIMD32_SET(ZBIT32((x) & 0xffffffff), SIMD_ZBIT, i) -#define NZBIT64(x) \ - SIMD64_SET(NBIT64(x), SIMD_NBIT) | \ - SIMD64_SET(ZBIT64(x), SIMD_ZBIT) -#define IWMMXT_OP_UNPACK(S, SH0, SH1, SH2, SH3) \ -uint64_t HELPER(glue(iwmmxt_unpack, glue(S, b)))(CPUState *env, \ - uint64_t a, uint64_t b) \ -{ \ - a = \ - (((a >> SH0) & 0xff) << 0) | (((b >> SH0) & 0xff) << 8) | \ - (((a >> SH1) & 0xff) << 16) | (((b >> SH1) & 0xff) << 24) | \ - (((a >> SH2) & 0xff) << 32) | (((b >> SH2) & 0xff) << 40) | \ - (((a >> SH3) & 0xff) << 48) | (((b >> SH3) & 0xff) << 56); \ - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = \ - NZBIT8(a >> 0, 0) | NZBIT8(a >> 8, 1) | \ - NZBIT8(a >> 16, 2) | NZBIT8(a >> 24, 3) | \ - NZBIT8(a >> 32, 4) | NZBIT8(a >> 40, 5) | \ - NZBIT8(a >> 48, 6) | NZBIT8(a >> 56, 7); \ - return a; \ -} \ -uint64_t HELPER(glue(iwmmxt_unpack, glue(S, w)))(CPUState *env, \ - uint64_t a, uint64_t b) \ -{ \ - a = \ - (((a >> SH0) & 0xffff) << 0) | \ - (((b >> SH0) & 0xffff) << 16) | \ - (((a >> SH2) & 0xffff) << 32) | \ - (((b >> SH2) & 0xffff) << 48); \ - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = \ - NZBIT8(a >> 0, 0) | NZBIT8(a >> 16, 1) | \ - NZBIT8(a >> 32, 2) | NZBIT8(a >> 48, 3); \ - return a; \ -} \ -uint64_t HELPER(glue(iwmmxt_unpack, glue(S, l)))(CPUState *env, \ - uint64_t a, uint64_t b) \ -{ \ - a = \ - (((a >> SH0) & 0xffffffff) << 0) | \ - (((b >> SH0) & 0xffffffff) << 32); \ - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = \ - NZBIT32(a >> 0, 0) | NZBIT32(a >> 32, 1); \ - return a; \ -} \ -uint64_t HELPER(glue(iwmmxt_unpack, glue(S, ub)))(CPUState *env, \ - uint64_t x) \ -{ \ - x = \ - (((x >> SH0) & 0xff) << 0) | \ - (((x >> SH1) & 0xff) << 16) | \ - (((x >> SH2) & 0xff) << 32) | \ - (((x >> SH3) & 0xff) << 48); \ - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = \ - NZBIT16(x >> 0, 0) | NZBIT16(x >> 16, 1) | \ - NZBIT16(x >> 32, 2) | NZBIT16(x >> 48, 3); \ - return x; \ -} \ -uint64_t HELPER(glue(iwmmxt_unpack, glue(S, uw)))(CPUState *env, \ - uint64_t x) \ -{ \ - x = \ - (((x >> SH0) & 0xffff) << 0) | \ - (((x >> SH2) & 0xffff) << 32); \ - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = \ - NZBIT32(x >> 0, 0) | NZBIT32(x >> 32, 1); \ - return x; \ -} \ -uint64_t HELPER(glue(iwmmxt_unpack, glue(S, ul)))(CPUState *env, \ - uint64_t x) \ -{ \ - x = (((x >> SH0) & 0xffffffff) << 0); \ - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = NZBIT64(x >> 0); \ - return x; \ -} \ -uint64_t HELPER(glue(iwmmxt_unpack, glue(S, sb)))(CPUState *env, \ - uint64_t x) \ -{ \ - x = \ - ((uint64_t) EXTEND8H((x >> SH0) & 0xff) << 0) | \ - ((uint64_t) EXTEND8H((x >> SH1) & 0xff) << 16) | \ - ((uint64_t) EXTEND8H((x >> SH2) & 0xff) << 32) | \ - ((uint64_t) EXTEND8H((x >> SH3) & 0xff) << 48); \ - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = \ - NZBIT16(x >> 0, 0) | NZBIT16(x >> 16, 1) | \ - NZBIT16(x >> 32, 2) | NZBIT16(x >> 48, 3); \ - return x; \ -} \ -uint64_t HELPER(glue(iwmmxt_unpack, glue(S, sw)))(CPUState *env, \ - uint64_t x) \ -{ \ - x = \ - ((uint64_t) EXTEND16((x >> SH0) & 0xffff) << 0) | \ - ((uint64_t) EXTEND16((x >> SH2) & 0xffff) << 32); \ - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = \ - NZBIT32(x >> 0, 0) | NZBIT32(x >> 32, 1); \ - return x; \ -} \ -uint64_t HELPER(glue(iwmmxt_unpack, glue(S, sl)))(CPUState *env, \ - uint64_t x) \ -{ \ - x = EXTEND32((x >> SH0) & 0xffffffff); \ - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = NZBIT64(x >> 0); \ - return x; \ -} -IWMMXT_OP_UNPACK(l, 0, 8, 16, 24) -IWMMXT_OP_UNPACK(h, 32, 40, 48, 56) - -#define IWMMXT_OP_CMP(SUFF, Tb, Tw, Tl, O) \ -uint64_t HELPER(glue(iwmmxt_, glue(SUFF, b)))(CPUState *env, \ - uint64_t a, uint64_t b) \ -{ \ - a = \ - CMP(0, Tb, O, 0xff) | CMP(8, Tb, O, 0xff) | \ - CMP(16, Tb, O, 0xff) | CMP(24, Tb, O, 0xff) | \ - CMP(32, Tb, O, 0xff) | CMP(40, Tb, O, 0xff) | \ - CMP(48, Tb, O, 0xff) | CMP(56, Tb, O, 0xff); \ - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = \ - NZBIT8(a >> 0, 0) | NZBIT8(a >> 8, 1) | \ - NZBIT8(a >> 16, 2) | NZBIT8(a >> 24, 3) | \ - NZBIT8(a >> 32, 4) | NZBIT8(a >> 40, 5) | \ - NZBIT8(a >> 48, 6) | NZBIT8(a >> 56, 7); \ - return a; \ -} \ -uint64_t HELPER(glue(iwmmxt_, glue(SUFF, w)))(CPUState *env, \ - uint64_t a, uint64_t b) \ -{ \ - a = CMP(0, Tw, O, 0xffff) | CMP(16, Tw, O, 0xffff) | \ - CMP(32, Tw, O, 0xffff) | CMP(48, Tw, O, 0xffff); \ - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = \ - NZBIT16(a >> 0, 0) | NZBIT16(a >> 16, 1) | \ - NZBIT16(a >> 32, 2) | NZBIT16(a >> 48, 3); \ - return a; \ -} \ -uint64_t HELPER(glue(iwmmxt_, glue(SUFF, l)))(CPUState *env, \ - uint64_t a, uint64_t b) \ -{ \ - a = CMP(0, Tl, O, 0xffffffff) | \ - CMP(32, Tl, O, 0xffffffff); \ - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = \ - NZBIT32(a >> 0, 0) | NZBIT32(a >> 32, 1); \ - return a; \ -} -#define CMP(SHR, TYPE, OPER, MASK) ((((TYPE) ((a >> SHR) & MASK) OPER \ - (TYPE) ((b >> SHR) & MASK)) ? (uint64_t) MASK : 0) << SHR) -IWMMXT_OP_CMP(cmpeq, uint8_t, uint16_t, uint32_t, ==) -IWMMXT_OP_CMP(cmpgts, int8_t, int16_t, int32_t, >) -IWMMXT_OP_CMP(cmpgtu, uint8_t, uint16_t, uint32_t, >) -#undef CMP -#define CMP(SHR, TYPE, OPER, MASK) ((((TYPE) ((a >> SHR) & MASK) OPER \ - (TYPE) ((b >> SHR) & MASK)) ? a : b) & ((uint64_t) MASK << SHR)) -IWMMXT_OP_CMP(mins, int8_t, int16_t, int32_t, <) -IWMMXT_OP_CMP(minu, uint8_t, uint16_t, uint32_t, <) -IWMMXT_OP_CMP(maxs, int8_t, int16_t, int32_t, >) -IWMMXT_OP_CMP(maxu, uint8_t, uint16_t, uint32_t, >) -#undef CMP -#define CMP(SHR, TYPE, OPER, MASK) ((uint64_t) (((TYPE) ((a >> SHR) & MASK) \ - OPER (TYPE) ((b >> SHR) & MASK)) & MASK) << SHR) -IWMMXT_OP_CMP(subn, uint8_t, uint16_t, uint32_t, -) -IWMMXT_OP_CMP(addn, uint8_t, uint16_t, uint32_t, +) -#undef CMP -/* TODO Signed- and Unsigned-Saturation */ -#define CMP(SHR, TYPE, OPER, MASK) ((uint64_t) (((TYPE) ((a >> SHR) & MASK) \ - OPER (TYPE) ((b >> SHR) & MASK)) & MASK) << SHR) -IWMMXT_OP_CMP(subu, uint8_t, uint16_t, uint32_t, -) -IWMMXT_OP_CMP(addu, uint8_t, uint16_t, uint32_t, +) -IWMMXT_OP_CMP(subs, int8_t, int16_t, int32_t, -) -IWMMXT_OP_CMP(adds, int8_t, int16_t, int32_t, +) -#undef CMP -#undef IWMMXT_OP_CMP - -#define AVGB(SHR) ((( \ - ((a >> SHR) & 0xff) + ((b >> SHR) & 0xff) + round) >> 1) << SHR) -#define IWMMXT_OP_AVGB(r) \ -uint64_t HELPER(iwmmxt_avgb##r)(CPUState *env, uint64_t a, uint64_t b) \ -{ \ - const int round = r; \ - a = AVGB(0) | AVGB(8) | AVGB(16) | AVGB(24) | \ - AVGB(32) | AVGB(40) | AVGB(48) | AVGB(56); \ - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = \ - SIMD8_SET(ZBIT8((a >> 0) & 0xff), SIMD_ZBIT, 0) | \ - SIMD8_SET(ZBIT8((a >> 8) & 0xff), SIMD_ZBIT, 1) | \ - SIMD8_SET(ZBIT8((a >> 16) & 0xff), SIMD_ZBIT, 2) | \ - SIMD8_SET(ZBIT8((a >> 24) & 0xff), SIMD_ZBIT, 3) | \ - SIMD8_SET(ZBIT8((a >> 32) & 0xff), SIMD_ZBIT, 4) | \ - SIMD8_SET(ZBIT8((a >> 40) & 0xff), SIMD_ZBIT, 5) | \ - SIMD8_SET(ZBIT8((a >> 48) & 0xff), SIMD_ZBIT, 6) | \ - SIMD8_SET(ZBIT8((a >> 56) & 0xff), SIMD_ZBIT, 7); \ - return a; \ -} -IWMMXT_OP_AVGB(0) -IWMMXT_OP_AVGB(1) -#undef IWMMXT_OP_AVGB -#undef AVGB - -#define AVGW(SHR) ((( \ - ((a >> SHR) & 0xffff) + ((b >> SHR) & 0xffff) + round) >> 1) << SHR) -#define IWMMXT_OP_AVGW(r) \ -uint64_t HELPER(iwmmxt_avgw##r)(CPUState *env, uint64_t a, uint64_t b) \ -{ \ - const int round = r; \ - a = AVGW(0) | AVGW(16) | AVGW(32) | AVGW(48); \ - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = \ - SIMD16_SET(ZBIT16((a >> 0) & 0xffff), SIMD_ZBIT, 0) | \ - SIMD16_SET(ZBIT16((a >> 16) & 0xffff), SIMD_ZBIT, 1) | \ - SIMD16_SET(ZBIT16((a >> 32) & 0xffff), SIMD_ZBIT, 2) | \ - SIMD16_SET(ZBIT16((a >> 48) & 0xffff), SIMD_ZBIT, 3); \ - return a; \ -} -IWMMXT_OP_AVGW(0) -IWMMXT_OP_AVGW(1) -#undef IWMMXT_OP_AVGW -#undef AVGW - -uint64_t HELPER(iwmmxt_msadb)(uint64_t a, uint64_t b) -{ - a = ((((a >> 0 ) & 0xffff) * ((b >> 0) & 0xffff) + - ((a >> 16) & 0xffff) * ((b >> 16) & 0xffff)) & 0xffffffff) | - ((((a >> 32) & 0xffff) * ((b >> 32) & 0xffff) + - ((a >> 48) & 0xffff) * ((b >> 48) & 0xffff)) << 32); - return a; -} - -uint64_t HELPER(iwmmxt_align)(uint64_t a, uint64_t b, uint32_t n) -{ - a >>= n << 3; - a |= b << (64 - (n << 3)); - return a; -} - -uint64_t HELPER(iwmmxt_insr)(uint64_t x, uint32_t a, uint32_t b, uint32_t n) -{ - x &= ~((uint64_t) b << n); - x |= (uint64_t) (a & b) << n; - return x; -} - -uint32_t HELPER(iwmmxt_setpsr_nz)(uint64_t x) -{ - return SIMD64_SET((x == 0), SIMD_ZBIT) | - SIMD64_SET((x & (1ULL << 63)), SIMD_NBIT); -} - -uint64_t HELPER(iwmmxt_bcstb)(uint32_t arg) -{ - arg &= 0xff; - return - ((uint64_t) arg << 0 ) | ((uint64_t) arg << 8 ) | - ((uint64_t) arg << 16) | ((uint64_t) arg << 24) | - ((uint64_t) arg << 32) | ((uint64_t) arg << 40) | - ((uint64_t) arg << 48) | ((uint64_t) arg << 56); -} - -uint64_t HELPER(iwmmxt_bcstw)(uint32_t arg) -{ - arg &= 0xffff; - return - ((uint64_t) arg << 0 ) | ((uint64_t) arg << 16) | - ((uint64_t) arg << 32) | ((uint64_t) arg << 48); -} - -uint64_t HELPER(iwmmxt_bcstl)(uint32_t arg) -{ - return arg | ((uint64_t) arg << 32); -} - -uint64_t HELPER(iwmmxt_addcb)(uint64_t x) -{ - return - ((x >> 0) & 0xff) + ((x >> 8) & 0xff) + - ((x >> 16) & 0xff) + ((x >> 24) & 0xff) + - ((x >> 32) & 0xff) + ((x >> 40) & 0xff) + - ((x >> 48) & 0xff) + ((x >> 56) & 0xff); -} - -uint64_t HELPER(iwmmxt_addcw)(uint64_t x) -{ - return - ((x >> 0) & 0xffff) + ((x >> 16) & 0xffff) + - ((x >> 32) & 0xffff) + ((x >> 48) & 0xffff); -} - -uint64_t HELPER(iwmmxt_addcl)(uint64_t x) -{ - return (x & 0xffffffff) + (x >> 32); -} - -uint32_t HELPER(iwmmxt_msbb)(uint64_t x) -{ - return - ((x >> 7) & 0x01) | ((x >> 14) & 0x02) | - ((x >> 21) & 0x04) | ((x >> 28) & 0x08) | - ((x >> 35) & 0x10) | ((x >> 42) & 0x20) | - ((x >> 49) & 0x40) | ((x >> 56) & 0x80); -} - -uint32_t HELPER(iwmmxt_msbw)(uint64_t x) -{ - return - ((x >> 15) & 0x01) | ((x >> 30) & 0x02) | - ((x >> 45) & 0x04) | ((x >> 52) & 0x08); -} - -uint32_t HELPER(iwmmxt_msbl)(uint64_t x) -{ - return ((x >> 31) & 0x01) | ((x >> 62) & 0x02); -} - -/* FIXME: Split wCASF setting into a separate op to avoid env use. */ -uint64_t HELPER(iwmmxt_srlw)(CPUState *env, uint64_t x, uint32_t n) -{ - x = (((x & (0xffffll << 0)) >> n) & (0xffffll << 0)) | - (((x & (0xffffll << 16)) >> n) & (0xffffll << 16)) | - (((x & (0xffffll << 32)) >> n) & (0xffffll << 32)) | - (((x & (0xffffll << 48)) >> n) & (0xffffll << 48)); - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = - NZBIT16(x >> 0, 0) | NZBIT16(x >> 16, 1) | - NZBIT16(x >> 32, 2) | NZBIT16(x >> 48, 3); - return x; -} - -uint64_t HELPER(iwmmxt_srll)(CPUState *env, uint64_t x, uint32_t n) -{ - x = ((x & (0xffffffffll << 0)) >> n) | - ((x >> n) & (0xffffffffll << 32)); - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = - NZBIT32(x >> 0, 0) | NZBIT32(x >> 32, 1); - return x; -} - -uint64_t HELPER(iwmmxt_srlq)(CPUState *env, uint64_t x, uint32_t n) -{ - x >>= n; - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = NZBIT64(x); - return x; -} - -uint64_t HELPER(iwmmxt_sllw)(CPUState *env, uint64_t x, uint32_t n) -{ - x = (((x & (0xffffll << 0)) << n) & (0xffffll << 0)) | - (((x & (0xffffll << 16)) << n) & (0xffffll << 16)) | - (((x & (0xffffll << 32)) << n) & (0xffffll << 32)) | - (((x & (0xffffll << 48)) << n) & (0xffffll << 48)); - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = - NZBIT16(x >> 0, 0) | NZBIT16(x >> 16, 1) | - NZBIT16(x >> 32, 2) | NZBIT16(x >> 48, 3); - return x; -} - -uint64_t HELPER(iwmmxt_slll)(CPUState *env, uint64_t x, uint32_t n) -{ - x = ((x << n) & (0xffffffffll << 0)) | - ((x & (0xffffffffll << 32)) << n); - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = - NZBIT32(x >> 0, 0) | NZBIT32(x >> 32, 1); - return x; -} - -uint64_t HELPER(iwmmxt_sllq)(CPUState *env, uint64_t x, uint32_t n) -{ - x <<= n; - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = NZBIT64(x); - return x; -} - -uint64_t HELPER(iwmmxt_sraw)(CPUState *env, uint64_t x, uint32_t n) -{ - x = ((uint64_t) ((EXTEND16(x >> 0) >> n) & 0xffff) << 0) | - ((uint64_t) ((EXTEND16(x >> 16) >> n) & 0xffff) << 16) | - ((uint64_t) ((EXTEND16(x >> 32) >> n) & 0xffff) << 32) | - ((uint64_t) ((EXTEND16(x >> 48) >> n) & 0xffff) << 48); - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = - NZBIT16(x >> 0, 0) | NZBIT16(x >> 16, 1) | - NZBIT16(x >> 32, 2) | NZBIT16(x >> 48, 3); - return x; -} - -uint64_t HELPER(iwmmxt_sral)(CPUState *env, uint64_t x, uint32_t n) -{ - x = (((EXTEND32(x >> 0) >> n) & 0xffffffff) << 0) | - (((EXTEND32(x >> 32) >> n) & 0xffffffff) << 32); - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = - NZBIT32(x >> 0, 0) | NZBIT32(x >> 32, 1); - return x; -} - -uint64_t HELPER(iwmmxt_sraq)(CPUState *env, uint64_t x, uint32_t n) -{ - x = (int64_t) x >> n; - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = NZBIT64(x); - return x; -} - -uint64_t HELPER(iwmmxt_rorw)(CPUState *env, uint64_t x, uint32_t n) -{ - x = ((((x & (0xffffll << 0)) >> n) | - ((x & (0xffffll << 0)) << (16 - n))) & (0xffffll << 0)) | - ((((x & (0xffffll << 16)) >> n) | - ((x & (0xffffll << 16)) << (16 - n))) & (0xffffll << 16)) | - ((((x & (0xffffll << 32)) >> n) | - ((x & (0xffffll << 32)) << (16 - n))) & (0xffffll << 32)) | - ((((x & (0xffffll << 48)) >> n) | - ((x & (0xffffll << 48)) << (16 - n))) & (0xffffll << 48)); - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = - NZBIT16(x >> 0, 0) | NZBIT16(x >> 16, 1) | - NZBIT16(x >> 32, 2) | NZBIT16(x >> 48, 3); - return x; -} - -uint64_t HELPER(iwmmxt_rorl)(CPUState *env, uint64_t x, uint32_t n) -{ - x = ((x & (0xffffffffll << 0)) >> n) | - ((x >> n) & (0xffffffffll << 32)) | - ((x << (32 - n)) & (0xffffffffll << 0)) | - ((x & (0xffffffffll << 32)) << (32 - n)); - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = - NZBIT32(x >> 0, 0) | NZBIT32(x >> 32, 1); - return x; -} - -uint64_t HELPER(iwmmxt_rorq)(CPUState *env, uint64_t x, uint32_t n) -{ - x = (x >> n) | (x << (64 - n)); - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = NZBIT64(x); - return x; -} - -uint64_t HELPER(iwmmxt_shufh)(CPUState *env, uint64_t x, uint32_t n) -{ - x = (((x >> ((n << 4) & 0x30)) & 0xffff) << 0) | - (((x >> ((n << 2) & 0x30)) & 0xffff) << 16) | - (((x >> ((n << 0) & 0x30)) & 0xffff) << 32) | - (((x >> ((n >> 2) & 0x30)) & 0xffff) << 48); - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = - NZBIT16(x >> 0, 0) | NZBIT16(x >> 16, 1) | - NZBIT16(x >> 32, 2) | NZBIT16(x >> 48, 3); - return x; -} - -/* TODO: Unsigned-Saturation */ -uint64_t HELPER(iwmmxt_packuw)(CPUState *env, uint64_t a, uint64_t b) -{ - a = (((a >> 0) & 0xff) << 0) | (((a >> 16) & 0xff) << 8) | - (((a >> 32) & 0xff) << 16) | (((a >> 48) & 0xff) << 24) | - (((b >> 0) & 0xff) << 32) | (((b >> 16) & 0xff) << 40) | - (((b >> 32) & 0xff) << 48) | (((b >> 48) & 0xff) << 56); - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = - NZBIT8(a >> 0, 0) | NZBIT8(a >> 8, 1) | - NZBIT8(a >> 16, 2) | NZBIT8(a >> 24, 3) | - NZBIT8(a >> 32, 4) | NZBIT8(a >> 40, 5) | - NZBIT8(a >> 48, 6) | NZBIT8(a >> 56, 7); - return a; -} - -uint64_t HELPER(iwmmxt_packul)(CPUState *env, uint64_t a, uint64_t b) -{ - a = (((a >> 0) & 0xffff) << 0) | (((a >> 32) & 0xffff) << 16) | - (((b >> 0) & 0xffff) << 32) | (((b >> 32) & 0xffff) << 48); - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = - NZBIT16(a >> 0, 0) | NZBIT16(a >> 16, 1) | - NZBIT16(a >> 32, 2) | NZBIT16(a >> 48, 3); - return a; -} - -uint64_t HELPER(iwmmxt_packuq)(CPUState *env, uint64_t a, uint64_t b) -{ - a = (a & 0xffffffff) | ((b & 0xffffffff) << 32); - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = - NZBIT32(a >> 0, 0) | NZBIT32(a >> 32, 1); - return a; -} - -/* TODO: Signed-Saturation */ -uint64_t HELPER(iwmmxt_packsw)(CPUState *env, uint64_t a, uint64_t b) -{ - a = (((a >> 0) & 0xff) << 0) | (((a >> 16) & 0xff) << 8) | - (((a >> 32) & 0xff) << 16) | (((a >> 48) & 0xff) << 24) | - (((b >> 0) & 0xff) << 32) | (((b >> 16) & 0xff) << 40) | - (((b >> 32) & 0xff) << 48) | (((b >> 48) & 0xff) << 56); - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = - NZBIT8(a >> 0, 0) | NZBIT8(a >> 8, 1) | - NZBIT8(a >> 16, 2) | NZBIT8(a >> 24, 3) | - NZBIT8(a >> 32, 4) | NZBIT8(a >> 40, 5) | - NZBIT8(a >> 48, 6) | NZBIT8(a >> 56, 7); - return a; -} - -uint64_t HELPER(iwmmxt_packsl)(CPUState *env, uint64_t a, uint64_t b) -{ - a = (((a >> 0) & 0xffff) << 0) | (((a >> 32) & 0xffff) << 16) | - (((b >> 0) & 0xffff) << 32) | (((b >> 32) & 0xffff) << 48); - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = - NZBIT16(a >> 0, 0) | NZBIT16(a >> 16, 1) | - NZBIT16(a >> 32, 2) | NZBIT16(a >> 48, 3); - return a; -} - -uint64_t HELPER(iwmmxt_packsq)(CPUState *env, uint64_t a, uint64_t b) -{ - a = (a & 0xffffffff) | ((b & 0xffffffff) << 32); - env->iwmmxt.cregs[ARM_IWMMXT_wCASF] = - NZBIT32(a >> 0, 0) | NZBIT32(a >> 32, 1); - return a; -} - -uint64_t HELPER(iwmmxt_muladdsl)(uint64_t c, uint32_t a, uint32_t b) -{ - return c + ((int32_t) EXTEND32(a) * (int32_t) EXTEND32(b)); -} - -uint64_t HELPER(iwmmxt_muladdsw)(uint64_t c, uint32_t a, uint32_t b) -{ - c += EXTEND32(EXTEND16S((a >> 0) & 0xffff) * - EXTEND16S((b >> 0) & 0xffff)); - c += EXTEND32(EXTEND16S((a >> 16) & 0xffff) * - EXTEND16S((b >> 16) & 0xffff)); - return c; -} - -uint64_t HELPER(iwmmxt_muladdswl)(uint64_t c, uint32_t a, uint32_t b) -{ - return c + (EXTEND32(EXTEND16S(a & 0xffff) * - EXTEND16S(b & 0xffff))); -} diff --git a/qemu/qemu-git/target-arm/.svn/text-base/neon_helper.c.svn-base b/qemu/qemu-git/target-arm/.svn/text-base/neon_helper.c.svn-base deleted file mode 100644 index 5e6452b..0000000 --- a/qemu/qemu-git/target-arm/.svn/text-base/neon_helper.c.svn-base +++ /dev/null @@ -1,1459 +0,0 @@ -/* - * ARM NEON vector operations. - * - * Copyright (c) 2007, 2008 CodeSourcery. - * Written by Paul Brook - * - * This code is licenced under the GNU GPL v2. - */ -#include -#include - -#include "cpu.h" -#include "exec-all.h" -#include "helpers.h" - -#define SIGNBIT (uint32_t)0x80000000 -#define SIGNBIT64 ((uint64_t)1 << 63) - -#define SET_QC() env->vfp.xregs[ARM_VFP_FPSCR] = CPSR_Q - -static float_status neon_float_status; -#define NFS &neon_float_status - -/* Helper routines to perform bitwise copies between float and int. */ -static inline float32 vfp_itos(uint32_t i) -{ - union { - uint32_t i; - float32 s; - } v; - - v.i = i; - return v.s; -} - -static inline uint32_t vfp_stoi(float32 s) -{ - union { - uint32_t i; - float32 s; - } v; - - v.s = s; - return v.i; -} - -#define NEON_TYPE1(name, type) \ -typedef struct \ -{ \ - type v1; \ -} neon_##name; -#ifdef HOST_WORDS_BIGENDIAN -#define NEON_TYPE2(name, type) \ -typedef struct \ -{ \ - type v2; \ - type v1; \ -} neon_##name; -#define NEON_TYPE4(name, type) \ -typedef struct \ -{ \ - type v4; \ - type v3; \ - type v2; \ - type v1; \ -} neon_##name; -#else -#define NEON_TYPE2(name, type) \ -typedef struct \ -{ \ - type v1; \ - type v2; \ -} neon_##name; -#define NEON_TYPE4(name, type) \ -typedef struct \ -{ \ - type v1; \ - type v2; \ - type v3; \ - type v4; \ -} neon_##name; -#endif - -NEON_TYPE4(s8, int8_t) -NEON_TYPE4(u8, uint8_t) -NEON_TYPE2(s16, int16_t) -NEON_TYPE2(u16, uint16_t) -NEON_TYPE1(s32, int32_t) -NEON_TYPE1(u32, uint32_t) -#undef NEON_TYPE4 -#undef NEON_TYPE2 -#undef NEON_TYPE1 - -/* Copy from a uint32_t to a vector structure type. */ -#define NEON_UNPACK(vtype, dest, val) do { \ - union { \ - vtype v; \ - uint32_t i; \ - } conv_u; \ - conv_u.i = (val); \ - dest = conv_u.v; \ - } while(0) - -/* Copy from a vector structure type to a uint32_t. */ -#define NEON_PACK(vtype, dest, val) do { \ - union { \ - vtype v; \ - uint32_t i; \ - } conv_u; \ - conv_u.v = (val); \ - dest = conv_u.i; \ - } while(0) - -#define NEON_DO1 \ - NEON_FN(vdest.v1, vsrc1.v1, vsrc2.v1); -#define NEON_DO2 \ - NEON_FN(vdest.v1, vsrc1.v1, vsrc2.v1); \ - NEON_FN(vdest.v2, vsrc1.v2, vsrc2.v2); -#define NEON_DO4 \ - NEON_FN(vdest.v1, vsrc1.v1, vsrc2.v1); \ - NEON_FN(vdest.v2, vsrc1.v2, vsrc2.v2); \ - NEON_FN(vdest.v3, vsrc1.v3, vsrc2.v3); \ - NEON_FN(vdest.v4, vsrc1.v4, vsrc2.v4); - -#define NEON_VOP_BODY(vtype, n) \ -{ \ - uint32_t res; \ - vtype vsrc1; \ - vtype vsrc2; \ - vtype vdest; \ - NEON_UNPACK(vtype, vsrc1, arg1); \ - NEON_UNPACK(vtype, vsrc2, arg2); \ - NEON_DO##n; \ - NEON_PACK(vtype, res, vdest); \ - return res; \ -} - -#define NEON_VOP(name, vtype, n) \ -uint32_t HELPER(glue(neon_,name))(uint32_t arg1, uint32_t arg2) \ -NEON_VOP_BODY(vtype, n) - -#define NEON_VOP_ENV(name, vtype, n) \ -uint32_t HELPER(glue(neon_,name))(CPUState *env, uint32_t arg1, uint32_t arg2) \ -NEON_VOP_BODY(vtype, n) - -/* Pairwise operations. */ -/* For 32-bit elements each segment only contains a single element, so - the elementwise and pairwise operations are the same. */ -#define NEON_PDO2 \ - NEON_FN(vdest.v1, vsrc1.v1, vsrc1.v2); \ - NEON_FN(vdest.v2, vsrc2.v1, vsrc2.v2); -#define NEON_PDO4 \ - NEON_FN(vdest.v1, vsrc1.v1, vsrc1.v2); \ - NEON_FN(vdest.v2, vsrc1.v3, vsrc1.v4); \ - NEON_FN(vdest.v3, vsrc2.v1, vsrc2.v2); \ - NEON_FN(vdest.v4, vsrc2.v3, vsrc2.v4); \ - -#define NEON_POP(name, vtype, n) \ -uint32_t HELPER(glue(neon_,name))(uint32_t arg1, uint32_t arg2) \ -{ \ - uint32_t res; \ - vtype vsrc1; \ - vtype vsrc2; \ - vtype vdest; \ - NEON_UNPACK(vtype, vsrc1, arg1); \ - NEON_UNPACK(vtype, vsrc2, arg2); \ - NEON_PDO##n; \ - NEON_PACK(vtype, res, vdest); \ - return res; \ -} - -/* Unary operators. */ -#define NEON_VOP1(name, vtype, n) \ -uint32_t HELPER(glue(neon_,name))(uint32_t arg) \ -{ \ - vtype vsrc1; \ - vtype vdest; \ - NEON_UNPACK(vtype, vsrc1, arg); \ - NEON_DO##n; \ - NEON_PACK(vtype, arg, vdest); \ - return arg; \ -} - - -#define NEON_USAT(dest, src1, src2, type) do { \ - uint32_t tmp = (uint32_t)src1 + (uint32_t)src2; \ - if (tmp != (type)tmp) { \ - SET_QC(); \ - dest = ~0; \ - } else { \ - dest = tmp; \ - }} while(0) -#define NEON_FN(dest, src1, src2) NEON_USAT(dest, src1, src2, uint8_t) -NEON_VOP_ENV(qadd_u8, neon_u8, 4) -#undef NEON_FN -#define NEON_FN(dest, src1, src2) NEON_USAT(dest, src1, src2, uint16_t) -NEON_VOP_ENV(qadd_u16, neon_u16, 2) -#undef NEON_FN -#undef NEON_USAT - -#define NEON_SSAT(dest, src1, src2, type) do { \ - int32_t tmp = (uint32_t)src1 + (uint32_t)src2; \ - if (tmp != (type)tmp) { \ - SET_QC(); \ - if (src2 > 0) { \ - tmp = (1 << (sizeof(type) * 8 - 1)) - 1; \ - } else { \ - tmp = 1 << (sizeof(type) * 8 - 1); \ - } \ - } \ - dest = tmp; \ - } while(0) -#define NEON_FN(dest, src1, src2) NEON_SSAT(dest, src1, src2, int8_t) -NEON_VOP_ENV(qadd_s8, neon_s8, 4) -#undef NEON_FN -#define NEON_FN(dest, src1, src2) NEON_SSAT(dest, src1, src2, int16_t) -NEON_VOP_ENV(qadd_s16, neon_s16, 2) -#undef NEON_FN -#undef NEON_SSAT - -#define NEON_USAT(dest, src1, src2, type) do { \ - uint32_t tmp = (uint32_t)src1 - (uint32_t)src2; \ - if (tmp != (type)tmp) { \ - SET_QC(); \ - dest = 0; \ - } else { \ - dest = tmp; \ - }} while(0) -#define NEON_FN(dest, src1, src2) NEON_USAT(dest, src1, src2, uint8_t) -NEON_VOP_ENV(qsub_u8, neon_u8, 4) -#undef NEON_FN -#define NEON_FN(dest, src1, src2) NEON_USAT(dest, src1, src2, uint16_t) -NEON_VOP_ENV(qsub_u16, neon_u16, 2) -#undef NEON_FN -#undef NEON_USAT - -#define NEON_SSAT(dest, src1, src2, type) do { \ - int32_t tmp = (uint32_t)src1 - (uint32_t)src2; \ - if (tmp != (type)tmp) { \ - SET_QC(); \ - if (src2 < 0) { \ - tmp = (1 << (sizeof(type) * 8 - 1)) - 1; \ - } else { \ - tmp = 1 << (sizeof(type) * 8 - 1); \ - } \ - } \ - dest = tmp; \ - } while(0) -#define NEON_FN(dest, src1, src2) NEON_SSAT(dest, src1, src2, int8_t) -NEON_VOP_ENV(qsub_s8, neon_s8, 4) -#undef NEON_FN -#define NEON_FN(dest, src1, src2) NEON_SSAT(dest, src1, src2, int16_t) -NEON_VOP_ENV(qsub_s16, neon_s16, 2) -#undef NEON_FN -#undef NEON_SSAT - -#define NEON_FN(dest, src1, src2) dest = (src1 + src2) >> 1 -NEON_VOP(hadd_s8, neon_s8, 4) -NEON_VOP(hadd_u8, neon_u8, 4) -NEON_VOP(hadd_s16, neon_s16, 2) -NEON_VOP(hadd_u16, neon_u16, 2) -#undef NEON_FN - -int32_t HELPER(neon_hadd_s32)(int32_t src1, int32_t src2) -{ - int32_t dest; - - dest = (src1 >> 1) + (src2 >> 1); - if (src1 & src2 & 1) - dest++; - return dest; -} - -uint32_t HELPER(neon_hadd_u32)(uint32_t src1, uint32_t src2) -{ - uint32_t dest; - - dest = (src1 >> 1) + (src2 >> 1); - if (src1 & src2 & 1) - dest++; - return dest; -} - -#define NEON_FN(dest, src1, src2) dest = (src1 + src2 + 1) >> 1 -NEON_VOP(rhadd_s8, neon_s8, 4) -NEON_VOP(rhadd_u8, neon_u8, 4) -NEON_VOP(rhadd_s16, neon_s16, 2) -NEON_VOP(rhadd_u16, neon_u16, 2) -#undef NEON_FN - -int32_t HELPER(neon_rhadd_s32)(int32_t src1, int32_t src2) -{ - int32_t dest; - - dest = (src1 >> 1) + (src2 >> 1); - if ((src1 | src2) & 1) - dest++; - return dest; -} - -uint32_t HELPER(neon_rhadd_u32)(uint32_t src1, uint32_t src2) -{ - uint32_t dest; - - dest = (src1 >> 1) + (src2 >> 1); - if ((src1 | src2) & 1) - dest++; - return dest; -} - -#define NEON_FN(dest, src1, src2) dest = (src1 - src2) >> 1 -NEON_VOP(hsub_s8, neon_s8, 4) -NEON_VOP(hsub_u8, neon_u8, 4) -NEON_VOP(hsub_s16, neon_s16, 2) -NEON_VOP(hsub_u16, neon_u16, 2) -#undef NEON_FN - -int32_t HELPER(neon_hsub_s32)(int32_t src1, int32_t src2) -{ - int32_t dest; - - dest = (src1 >> 1) - (src2 >> 1); - if ((~src1) & src2 & 1) - dest--; - return dest; -} - -uint32_t HELPER(neon_hsub_u32)(uint32_t src1, uint32_t src2) -{ - uint32_t dest; - - dest = (src1 >> 1) - (src2 >> 1); - if ((~src1) & src2 & 1) - dest--; - return dest; -} - -#define NEON_FN(dest, src1, src2) dest = (src1 > src2) ? ~0 : 0 -NEON_VOP(cgt_s8, neon_s8, 4) -NEON_VOP(cgt_u8, neon_u8, 4) -NEON_VOP(cgt_s16, neon_s16, 2) -NEON_VOP(cgt_u16, neon_u16, 2) -NEON_VOP(cgt_s32, neon_s32, 1) -NEON_VOP(cgt_u32, neon_u32, 1) -#undef NEON_FN - -#define NEON_FN(dest, src1, src2) dest = (src1 >= src2) ? ~0 : 0 -NEON_VOP(cge_s8, neon_s8, 4) -NEON_VOP(cge_u8, neon_u8, 4) -NEON_VOP(cge_s16, neon_s16, 2) -NEON_VOP(cge_u16, neon_u16, 2) -NEON_VOP(cge_s32, neon_s32, 1) -NEON_VOP(cge_u32, neon_u32, 1) -#undef NEON_FN - -#define NEON_FN(dest, src1, src2) dest = (src1 < src2) ? src1 : src2 -NEON_VOP(min_s8, neon_s8, 4) -NEON_VOP(min_u8, neon_u8, 4) -NEON_VOP(min_s16, neon_s16, 2) -NEON_VOP(min_u16, neon_u16, 2) -NEON_VOP(min_s32, neon_s32, 1) -NEON_VOP(min_u32, neon_u32, 1) -NEON_POP(pmin_s8, neon_s8, 4) -NEON_POP(pmin_u8, neon_u8, 4) -NEON_POP(pmin_s16, neon_s16, 2) -NEON_POP(pmin_u16, neon_u16, 2) -#undef NEON_FN - -#define NEON_FN(dest, src1, src2) dest = (src1 > src2) ? src1 : src2 -NEON_VOP(max_s8, neon_s8, 4) -NEON_VOP(max_u8, neon_u8, 4) -NEON_VOP(max_s16, neon_s16, 2) -NEON_VOP(max_u16, neon_u16, 2) -NEON_VOP(max_s32, neon_s32, 1) -NEON_VOP(max_u32, neon_u32, 1) -NEON_POP(pmax_s8, neon_s8, 4) -NEON_POP(pmax_u8, neon_u8, 4) -NEON_POP(pmax_s16, neon_s16, 2) -NEON_POP(pmax_u16, neon_u16, 2) -#undef NEON_FN - -#define NEON_FN(dest, src1, src2) \ - dest = (src1 > src2) ? (src1 - src2) : (src2 - src1) -NEON_VOP(abd_s8, neon_s8, 4) -NEON_VOP(abd_u8, neon_u8, 4) -NEON_VOP(abd_s16, neon_s16, 2) -NEON_VOP(abd_u16, neon_u16, 2) -NEON_VOP(abd_s32, neon_s32, 1) -NEON_VOP(abd_u32, neon_u32, 1) -#undef NEON_FN - -#define NEON_FN(dest, src1, src2) do { \ - int8_t tmp; \ - tmp = (int8_t)src2; \ - if (tmp >= (ssize_t)sizeof(src1) * 8 || \ - tmp <= -(ssize_t)sizeof(src1) * 8) { \ - dest = 0; \ - } else if (tmp < 0) { \ - dest = src1 >> -tmp; \ - } else { \ - dest = src1 << tmp; \ - }} while (0) -NEON_VOP(shl_u8, neon_u8, 4) -NEON_VOP(shl_u16, neon_u16, 2) -NEON_VOP(shl_u32, neon_u32, 1) -#undef NEON_FN - -uint64_t HELPER(neon_shl_u64)(uint64_t val, uint64_t shiftop) -{ - int8_t shift = (int8_t)shiftop; - if (shift >= 64 || shift <= -64) { - val = 0; - } else if (shift < 0) { - val >>= -shift; - } else { - val <<= shift; - } - return val; -} - -#define NEON_FN(dest, src1, src2) do { \ - int8_t tmp; \ - tmp = (int8_t)src2; \ - if (tmp >= (ssize_t)sizeof(src1) * 8) { \ - dest = 0; \ - } else if (tmp <= -(ssize_t)sizeof(src1) * 8) { \ - dest = src1 >> (sizeof(src1) * 8 - 1); \ - } else if (tmp < 0) { \ - dest = src1 >> -tmp; \ - } else { \ - dest = src1 << tmp; \ - }} while (0) -NEON_VOP(shl_s8, neon_s8, 4) -NEON_VOP(shl_s16, neon_s16, 2) -NEON_VOP(shl_s32, neon_s32, 1) -#undef NEON_FN - -uint64_t HELPER(neon_shl_s64)(uint64_t valop, uint64_t shiftop) -{ - int8_t shift = (int8_t)shiftop; - int64_t val = valop; - if (shift >= 64) { - val = 0; - } else if (shift <= -64) { - val >>= 63; - } else if (shift < 0) { - val >>= -shift; - } else { - val <<= shift; - } - return val; -} - -#define NEON_FN(dest, src1, src2) do { \ - int8_t tmp; \ - tmp = (int8_t)src2; \ - if (tmp >= (ssize_t)sizeof(src1) * 8) { \ - dest = 0; \ - } else if (tmp < -(ssize_t)sizeof(src1) * 8) { \ - dest = src1 >> (sizeof(src1) * 8 - 1); \ - } else if (tmp == -(ssize_t)sizeof(src1) * 8) { \ - dest = src1 >> (tmp - 1); \ - dest++; \ - dest >>= 1; \ - } else if (tmp < 0) { \ - dest = (src1 + (1 << (-1 - tmp))) >> -tmp; \ - } else { \ - dest = src1 << tmp; \ - }} while (0) -NEON_VOP(rshl_s8, neon_s8, 4) -NEON_VOP(rshl_s16, neon_s16, 2) -NEON_VOP(rshl_s32, neon_s32, 1) -#undef NEON_FN - -uint64_t HELPER(neon_rshl_s64)(uint64_t valop, uint64_t shiftop) -{ - int8_t shift = (int8_t)shiftop; - int64_t val = valop; - if (shift >= 64) { - val = 0; - } else if (shift < -64) { - val >>= 63; - } else if (shift == -63) { - val >>= 63; - val++; - val >>= 1; - } else if (shift < 0) { - val = (val + ((int64_t)1 << (-1 - shift))) >> -shift; - } else { - val <<= shift; - } - return val; -} - -#define NEON_FN(dest, src1, src2) do { \ - int8_t tmp; \ - tmp = (int8_t)src2; \ - if (tmp >= (ssize_t)sizeof(src1) * 8 || \ - tmp < -(ssize_t)sizeof(src1) * 8) { \ - dest = 0; \ - } else if (tmp == -(ssize_t)sizeof(src1) * 8) { \ - dest = src1 >> (tmp - 1); \ - } else if (tmp < 0) { \ - dest = (src1 + (1 << (-1 - tmp))) >> -tmp; \ - } else { \ - dest = src1 << tmp; \ - }} while (0) -NEON_VOP(rshl_u8, neon_u8, 4) -NEON_VOP(rshl_u16, neon_u16, 2) -NEON_VOP(rshl_u32, neon_u32, 1) -#undef NEON_FN - -uint64_t HELPER(neon_rshl_u64)(uint64_t val, uint64_t shiftop) -{ - int8_t shift = (uint8_t)shiftop; - if (shift >= 64 || shift < 64) { - val = 0; - } else if (shift == -64) { - /* Rounding a 1-bit result just preserves that bit. */ - val >>= 63; - } if (shift < 0) { - val = (val + ((uint64_t)1 << (-1 - shift))) >> -shift; - val >>= -shift; - } else { - val <<= shift; - } - return val; -} - -#define NEON_FN(dest, src1, src2) do { \ - int8_t tmp; \ - tmp = (int8_t)src2; \ - if (tmp >= (ssize_t)sizeof(src1) * 8) { \ - if (src1) { \ - SET_QC(); \ - dest = ~0; \ - } else { \ - dest = 0; \ - } \ - } else if (tmp <= -(ssize_t)sizeof(src1) * 8) { \ - dest = 0; \ - } else if (tmp < 0) { \ - dest = src1 >> -tmp; \ - } else { \ - dest = src1 << tmp; \ - if ((dest >> tmp) != src1) { \ - SET_QC(); \ - dest = ~0; \ - } \ - }} while (0) -NEON_VOP_ENV(qshl_u8, neon_u8, 4) -NEON_VOP_ENV(qshl_u16, neon_u16, 2) -NEON_VOP_ENV(qshl_u32, neon_u32, 1) -#undef NEON_FN - -uint64_t HELPER(neon_qshl_u64)(CPUState *env, uint64_t val, uint64_t shiftop) -{ - int8_t shift = (int8_t)shiftop; - if (shift >= 64) { - if (val) { - val = ~(uint64_t)0; - SET_QC(); - } else { - val = 0; - } - } else if (shift <= -64) { - val = 0; - } else if (shift < 0) { - val >>= -shift; - } else { - uint64_t tmp = val; - val <<= shift; - if ((val >> shift) != tmp) { - SET_QC(); - val = ~(uint64_t)0; - } - } - return val; -} - -#define NEON_FN(dest, src1, src2) do { \ - int8_t tmp; \ - tmp = (int8_t)src2; \ - if (tmp >= (ssize_t)sizeof(src1) * 8) { \ - if (src1) \ - SET_QC(); \ - dest = src1 >> 31; \ - } else if (tmp <= -(ssize_t)sizeof(src1) * 8) { \ - dest = src1 >> 31; \ - } else if (tmp < 0) { \ - dest = src1 >> -tmp; \ - } else { \ - dest = src1 << tmp; \ - if ((dest >> tmp) != src1) { \ - SET_QC(); \ - dest = src2 >> 31; \ - } \ - }} while (0) -NEON_VOP_ENV(qshl_s8, neon_s8, 4) -NEON_VOP_ENV(qshl_s16, neon_s16, 2) -NEON_VOP_ENV(qshl_s32, neon_s32, 1) -#undef NEON_FN - -uint64_t HELPER(neon_qshl_s64)(CPUState *env, uint64_t valop, uint64_t shiftop) -{ - int8_t shift = (uint8_t)shiftop; - int64_t val = valop; - if (shift >= 64) { - if (val) { - SET_QC(); - val = (val >> 63) & ~SIGNBIT64; - } - } else if (shift <= 64) { - val >>= 63; - } else if (shift < 0) { - val >>= -shift; - } else { - int64_t tmp = val; - val <<= shift; - if ((val >> shift) != tmp) { - SET_QC(); - val = (tmp >> 63) ^ ~SIGNBIT64; - } - } - return val; -} - - -/* FIXME: This is wrong. */ -#define NEON_FN(dest, src1, src2) do { \ - int8_t tmp; \ - tmp = (int8_t)src2; \ - if (tmp < 0) { \ - dest = (src1 + (1 << (-1 - tmp))) >> -tmp; \ - } else { \ - dest = src1 << tmp; \ - if ((dest >> tmp) != src1) { \ - SET_QC(); \ - dest = ~0; \ - } \ - }} while (0) -NEON_VOP_ENV(qrshl_u8, neon_u8, 4) -NEON_VOP_ENV(qrshl_u16, neon_u16, 2) -NEON_VOP_ENV(qrshl_u32, neon_u32, 1) -#undef NEON_FN - -uint64_t HELPER(neon_qrshl_u64)(CPUState *env, uint64_t val, uint64_t shiftop) -{ - int8_t shift = (int8_t)shiftop; - if (shift < 0) { - val = (val + (1 << (-1 - shift))) >> -shift; - } else { \ - uint64_t tmp = val; - val <<= shift; - if ((val >> shift) != tmp) { - SET_QC(); - val = ~0; - } - } - return val; -} - -#define NEON_FN(dest, src1, src2) do { \ - int8_t tmp; \ - tmp = (int8_t)src2; \ - if (tmp < 0) { \ - dest = (src1 + (1 << (-1 - tmp))) >> -tmp; \ - } else { \ - dest = src1 << tmp; \ - if ((dest >> tmp) != src1) { \ - SET_QC(); \ - dest = src1 >> 31; \ - } \ - }} while (0) -NEON_VOP_ENV(qrshl_s8, neon_s8, 4) -NEON_VOP_ENV(qrshl_s16, neon_s16, 2) -NEON_VOP_ENV(qrshl_s32, neon_s32, 1) -#undef NEON_FN - -uint64_t HELPER(neon_qrshl_s64)(CPUState *env, uint64_t valop, uint64_t shiftop) -{ - int8_t shift = (uint8_t)shiftop; - int64_t val = valop; - - if (shift < 0) { - val = (val + (1 << (-1 - shift))) >> -shift; - } else { - int64_t tmp = val;; - val <<= shift; - if ((val >> shift) != tmp) { - SET_QC(); - val = tmp >> 31; - } - } - return val; -} - -uint32_t HELPER(neon_add_u8)(uint32_t a, uint32_t b) -{ - uint32_t mask; - mask = (a ^ b) & 0x80808080u; - a &= ~0x80808080u; - b &= ~0x80808080u; - return (a + b) ^ mask; -} - -uint32_t HELPER(neon_add_u16)(uint32_t a, uint32_t b) -{ - uint32_t mask; - mask = (a ^ b) & 0x80008000u; - a &= ~0x80008000u; - b &= ~0x80008000u; - return (a + b) ^ mask; -} - -#define NEON_FN(dest, src1, src2) dest = src1 + src2 -NEON_POP(padd_u8, neon_u8, 4) -NEON_POP(padd_u16, neon_u16, 2) -#undef NEON_FN - -#define NEON_FN(dest, src1, src2) dest = src1 - src2 -NEON_VOP(sub_u8, neon_u8, 4) -NEON_VOP(sub_u16, neon_u16, 2) -#undef NEON_FN - -#define NEON_FN(dest, src1, src2) dest = src1 * src2 -NEON_VOP(mul_u8, neon_u8, 4) -NEON_VOP(mul_u16, neon_u16, 2) -#undef NEON_FN - -/* Polynomial multiplication is like integer multiplication except the - partial products are XORed, not added. */ -uint32_t HELPER(neon_mul_p8)(uint32_t op1, uint32_t op2) -{ - uint32_t mask; - uint32_t result; - result = 0; - while (op1) { - mask = 0; - if (op1 & 1) - mask |= 0xff; - if (op1 & (1 << 8)) - mask |= (0xff << 8); - if (op1 & (1 << 16)) - mask |= (0xff << 16); - if (op1 & (1 << 24)) - mask |= (0xff << 24); - result ^= op2 & mask; - op1 = (op1 >> 1) & 0x7f7f7f7f; - op2 = (op2 << 1) & 0xfefefefe; - } - return result; -} - -#define NEON_FN(dest, src1, src2) dest = (src1 & src2) ? -1 : 0 -NEON_VOP(tst_u8, neon_u8, 4) -NEON_VOP(tst_u16, neon_u16, 2) -NEON_VOP(tst_u32, neon_u32, 1) -#undef NEON_FN - -#define NEON_FN(dest, src1, src2) dest = (src1 == src2) ? -1 : 0 -NEON_VOP(ceq_u8, neon_u8, 4) -NEON_VOP(ceq_u16, neon_u16, 2) -NEON_VOP(ceq_u32, neon_u32, 1) -#undef NEON_FN - -#define NEON_FN(dest, src, dummy) dest = (src < 0) ? -src : src -NEON_VOP1(abs_s8, neon_s8, 4) -NEON_VOP1(abs_s16, neon_s16, 2) -#undef NEON_FN - -/* Count Leading Sign/Zero Bits. */ -static inline int do_clz8(uint8_t x) -{ - int n; - for (n = 8; x; n--) - x >>= 1; - return n; -} - -static inline int do_clz16(uint16_t x) -{ - int n; - for (n = 16; x; n--) - x >>= 1; - return n; -} - -#define NEON_FN(dest, src, dummy) dest = do_clz8(src) -NEON_VOP1(clz_u8, neon_u8, 4) -#undef NEON_FN - -#define NEON_FN(dest, src, dummy) dest = do_clz16(src) -NEON_VOP1(clz_u16, neon_u16, 2) -#undef NEON_FN - -#define NEON_FN(dest, src, dummy) dest = do_clz8((src < 0) ? ~src : src) - 1 -NEON_VOP1(cls_s8, neon_s8, 4) -#undef NEON_FN - -#define NEON_FN(dest, src, dummy) dest = do_clz16((src < 0) ? ~src : src) - 1 -NEON_VOP1(cls_s16, neon_s16, 2) -#undef NEON_FN - -uint32_t HELPER(neon_cls_s32)(uint32_t x) -{ - int count; - if ((int32_t)x < 0) - x = ~x; - for (count = 32; x; count--) - x = x >> 1; - return count - 1; -} - -/* Bit count. */ -uint32_t HELPER(neon_cnt_u8)(uint32_t x) -{ - x = (x & 0x55555555) + ((x >> 1) & 0x55555555); - x = (x & 0x33333333) + ((x >> 2) & 0x33333333); - x = (x & 0x0f0f0f0f) + ((x >> 4) & 0x0f0f0f0f); - return x; -} - -#define NEON_QDMULH16(dest, src1, src2, round) do { \ - uint32_t tmp = (int32_t)(int16_t) src1 * (int16_t) src2; \ - if ((tmp ^ (tmp << 1)) & SIGNBIT) { \ - SET_QC(); \ - tmp = (tmp >> 31) ^ ~SIGNBIT; \ - } \ - tmp <<= 1; \ - if (round) { \ - int32_t old = tmp; \ - tmp += 1 << 15; \ - if ((int32_t)tmp < old) { \ - SET_QC(); \ - tmp = SIGNBIT - 1; \ - } \ - } \ - dest = tmp >> 16; \ - } while(0) -#define NEON_FN(dest, src1, src2) NEON_QDMULH16(dest, src1, src2, 0) -NEON_VOP_ENV(qdmulh_s16, neon_s16, 2) -#undef NEON_FN -#define NEON_FN(dest, src1, src2) NEON_QDMULH16(dest, src1, src2, 1) -NEON_VOP_ENV(qrdmulh_s16, neon_s16, 2) -#undef NEON_FN -#undef NEON_QDMULH16 - -#define NEON_QDMULH32(dest, src1, src2, round) do { \ - uint64_t tmp = (int64_t)(int32_t) src1 * (int32_t) src2; \ - if ((tmp ^ (tmp << 1)) & SIGNBIT64) { \ - SET_QC(); \ - tmp = (tmp >> 63) ^ ~SIGNBIT64; \ - } else { \ - tmp <<= 1; \ - } \ - if (round) { \ - int64_t old = tmp; \ - tmp += (int64_t)1 << 31; \ - if ((int64_t)tmp < old) { \ - SET_QC(); \ - tmp = SIGNBIT64 - 1; \ - } \ - } \ - dest = tmp >> 32; \ - } while(0) -#define NEON_FN(dest, src1, src2) NEON_QDMULH32(dest, src1, src2, 0) -NEON_VOP_ENV(qdmulh_s32, neon_s32, 1) -#undef NEON_FN -#define NEON_FN(dest, src1, src2) NEON_QDMULH32(dest, src1, src2, 1) -NEON_VOP_ENV(qrdmulh_s32, neon_s32, 1) -#undef NEON_FN -#undef NEON_QDMULH32 - -uint32_t HELPER(neon_narrow_u8)(uint64_t x) -{ - return (x & 0xffu) | ((x >> 8) & 0xff00u) | ((x >> 16) & 0xff0000u) - | ((x >> 24) & 0xff000000u); -} - -uint32_t HELPER(neon_narrow_u16)(uint64_t x) -{ - return (x & 0xffffu) | ((x >> 16) & 0xffff0000u); -} - -uint32_t HELPER(neon_narrow_high_u8)(uint64_t x) -{ - return ((x >> 8) & 0xff) | ((x >> 16) & 0xff00) - | ((x >> 24) & 0xff0000) | ((x >> 32) & 0xff000000); -} - -uint32_t HELPER(neon_narrow_high_u16)(uint64_t x) -{ - return ((x >> 16) & 0xffff) | ((x >> 32) & 0xffff0000); -} - -uint32_t HELPER(neon_narrow_round_high_u8)(uint64_t x) -{ - x &= 0xff80ff80ff80ff80ull; - x += 0x0080008000800080ull; - return ((x >> 8) & 0xff) | ((x >> 16) & 0xff00) - | ((x >> 24) & 0xff0000) | ((x >> 32) & 0xff000000); -} - -uint32_t HELPER(neon_narrow_round_high_u16)(uint64_t x) -{ - x &= 0xffff8000ffff8000ull; - x += 0x0000800000008000ull; - return ((x >> 16) & 0xffff) | ((x >> 32) & 0xffff0000); -} - -uint32_t HELPER(neon_narrow_sat_u8)(CPUState *env, uint64_t x) -{ - uint16_t s; - uint8_t d; - uint32_t res = 0; -#define SAT8(n) \ - s = x >> n; \ - if (s > 0xff) { \ - d = 0xff; \ - SET_QC(); \ - } else { \ - d = s; \ - } \ - res |= (uint32_t)d << (n / 2); - - SAT8(0); - SAT8(16); - SAT8(32); - SAT8(48); -#undef SAT8 - return res; -} - -uint32_t HELPER(neon_narrow_sat_s8)(CPUState *env, uint64_t x) -{ - int16_t s; - uint8_t d; - uint32_t res = 0; -#define SAT8(n) \ - s = x >> n; \ - if (s != (int8_t)s) { \ - d = (s >> 15) ^ 0x7f; \ - SET_QC(); \ - } else { \ - d = s; \ - } \ - res |= (uint32_t)d << (n / 2); - - SAT8(0); - SAT8(16); - SAT8(32); - SAT8(48); -#undef SAT8 - return res; -} - -uint32_t HELPER(neon_narrow_sat_u16)(CPUState *env, uint64_t x) -{ - uint32_t high; - uint32_t low; - low = x; - if (low > 0xffff) { - low = 0xffff; - SET_QC(); - } - high = x >> 32; - if (high > 0xffff) { - high = 0xffff; - SET_QC(); - } - return low | (high << 16); -} - -uint32_t HELPER(neon_narrow_sat_s16)(CPUState *env, uint64_t x) -{ - int32_t low; - int32_t high; - low = x; - if (low != (int16_t)low) { - low = (low >> 31) ^ 0x7fff; - SET_QC(); - } - high = x >> 32; - if (high != (int16_t)high) { - high = (high >> 31) ^ 0x7fff; - SET_QC(); - } - return (uint16_t)low | (high << 16); -} - -uint32_t HELPER(neon_narrow_sat_u32)(CPUState *env, uint64_t x) -{ - if (x > 0xffffffffu) { - SET_QC(); - return 0xffffffffu; - } - return x; -} - -uint32_t HELPER(neon_narrow_sat_s32)(CPUState *env, uint64_t x) -{ - if ((int64_t)x != (int32_t)x) { - SET_QC(); - return (x >> 63) ^ 0x7fffffff; - } - return x; -} - -uint64_t HELPER(neon_widen_u8)(uint32_t x) -{ - uint64_t tmp; - uint64_t ret; - ret = (uint8_t)x; - tmp = (uint8_t)(x >> 8); - ret |= tmp << 16; - tmp = (uint8_t)(x >> 16); - ret |= tmp << 32; - tmp = (uint8_t)(x >> 24); - ret |= tmp << 48; - return ret; -} - -uint64_t HELPER(neon_widen_s8)(uint32_t x) -{ - uint64_t tmp; - uint64_t ret; - ret = (uint16_t)(int8_t)x; - tmp = (uint16_t)(int8_t)(x >> 8); - ret |= tmp << 16; - tmp = (uint16_t)(int8_t)(x >> 16); - ret |= tmp << 32; - tmp = (uint16_t)(int8_t)(x >> 24); - ret |= tmp << 48; - return ret; -} - -uint64_t HELPER(neon_widen_u16)(uint32_t x) -{ - uint64_t high = (uint16_t)(x >> 16); - return ((uint16_t)x) | (high << 32); -} - -uint64_t HELPER(neon_widen_s16)(uint32_t x) -{ - uint64_t high = (int16_t)(x >> 16); - return ((uint32_t)(int16_t)x) | (high << 32); -} - -uint64_t HELPER(neon_addl_u16)(uint64_t a, uint64_t b) -{ - uint64_t mask; - mask = (a ^ b) & 0x8000800080008000ull; - a &= ~0x8000800080008000ull; - b &= ~0x8000800080008000ull; - return (a + b) ^ mask; -} - -uint64_t HELPER(neon_addl_u32)(uint64_t a, uint64_t b) -{ - uint64_t mask; - mask = (a ^ b) & 0x8000000080000000ull; - a &= ~0x8000000080000000ull; - b &= ~0x8000000080000000ull; - return (a + b) ^ mask; -} - -uint64_t HELPER(neon_paddl_u16)(uint64_t a, uint64_t b) -{ - uint64_t tmp; - uint64_t tmp2; - - tmp = a & 0x0000ffff0000ffffull; - tmp += (a >> 16) & 0x0000ffff0000ffffull; - tmp2 = b & 0xffff0000ffff0000ull; - tmp2 += (b << 16) & 0xffff0000ffff0000ull; - return ( tmp & 0xffff) - | ((tmp >> 16) & 0xffff0000ull) - | ((tmp2 << 16) & 0xffff00000000ull) - | ( tmp2 & 0xffff000000000000ull); -} - -uint64_t HELPER(neon_paddl_u32)(uint64_t a, uint64_t b) -{ - uint32_t low = a + (a >> 32); - uint32_t high = b + (b >> 32); - return low + ((uint64_t)high << 32); -} - -uint64_t HELPER(neon_subl_u16)(uint64_t a, uint64_t b) -{ - uint64_t mask; - mask = (a ^ ~b) & 0x8000800080008000ull; - a |= 0x8000800080008000ull; - b &= ~0x8000800080008000ull; - return (a - b) ^ mask; -} - -uint64_t HELPER(neon_subl_u32)(uint64_t a, uint64_t b) -{ - uint64_t mask; - mask = (a ^ ~b) & 0x8000000080000000ull; - a |= 0x8000000080000000ull; - b &= ~0x8000000080000000ull; - return (a - b) ^ mask; -} - -uint64_t HELPER(neon_addl_saturate_s32)(CPUState *env, uint64_t a, uint64_t b) -{ - uint32_t x, y; - uint32_t low, high; - - x = a; - y = b; - low = x + y; - if (((low ^ x) & SIGNBIT) && !((x ^ y) & SIGNBIT)) { - SET_QC(); - low = ((int32_t)x >> 31) ^ ~SIGNBIT; - } - x = a >> 32; - y = b >> 32; - high = x + y; - if (((high ^ x) & SIGNBIT) && !((x ^ y) & SIGNBIT)) { - SET_QC(); - high = ((int32_t)x >> 31) ^ ~SIGNBIT; - } - return low | ((uint64_t)high << 32); -} - -uint64_t HELPER(neon_addl_saturate_s64)(CPUState *env, uint64_t a, uint64_t b) -{ - uint64_t result; - - result = a + b; - if (((result ^ a) & SIGNBIT64) && !((a ^ b) & SIGNBIT64)) { - SET_QC(); - result = ((int64_t)a >> 63) ^ ~SIGNBIT64; - } - return result; -} - -#define DO_ABD(dest, x, y, type) do { \ - type tmp_x = x; \ - type tmp_y = y; \ - dest = ((tmp_x > tmp_y) ? tmp_x - tmp_y : tmp_y - tmp_x); \ - } while(0) - -uint64_t HELPER(neon_abdl_u16)(uint32_t a, uint32_t b) -{ - uint64_t tmp; - uint64_t result; - DO_ABD(result, a, b, uint8_t); - DO_ABD(tmp, a >> 8, b >> 8, uint8_t); - result |= tmp << 16; - DO_ABD(tmp, a >> 16, b >> 16, uint8_t); - result |= tmp << 32; - DO_ABD(tmp, a >> 24, b >> 24, uint8_t); - result |= tmp << 48; - return result; -} - -uint64_t HELPER(neon_abdl_s16)(uint32_t a, uint32_t b) -{ - uint64_t tmp; - uint64_t result; - DO_ABD(result, a, b, int8_t); - DO_ABD(tmp, a >> 8, b >> 8, int8_t); - result |= tmp << 16; - DO_ABD(tmp, a >> 16, b >> 16, int8_t); - result |= tmp << 32; - DO_ABD(tmp, a >> 24, b >> 24, int8_t); - result |= tmp << 48; - return result; -} - -uint64_t HELPER(neon_abdl_u32)(uint32_t a, uint32_t b) -{ - uint64_t tmp; - uint64_t result; - DO_ABD(result, a, b, uint16_t); - DO_ABD(tmp, a >> 16, b >> 16, uint16_t); - return result | (tmp << 32); -} - -uint64_t HELPER(neon_abdl_s32)(uint32_t a, uint32_t b) -{ - uint64_t tmp; - uint64_t result; - DO_ABD(result, a, b, int16_t); - DO_ABD(tmp, a >> 16, b >> 16, int16_t); - return result | (tmp << 32); -} - -uint64_t HELPER(neon_abdl_u64)(uint32_t a, uint32_t b) -{ - uint64_t result; - DO_ABD(result, a, b, uint32_t); - return result; -} - -uint64_t HELPER(neon_abdl_s64)(uint32_t a, uint32_t b) -{ - uint64_t result; - DO_ABD(result, a, b, int32_t); - return result; -} -#undef DO_ABD - -/* Widening multiply. Named type is the source type. */ -#define DO_MULL(dest, x, y, type1, type2) do { \ - type1 tmp_x = x; \ - type1 tmp_y = y; \ - dest = (type2)((type2)tmp_x * (type2)tmp_y); \ - } while(0) - -uint64_t HELPER(neon_mull_u8)(uint32_t a, uint32_t b) -{ - uint64_t tmp; - uint64_t result; - - DO_MULL(result, a, b, uint8_t, uint16_t); - DO_MULL(tmp, a >> 8, b >> 8, uint8_t, uint16_t); - result |= tmp << 16; - DO_MULL(tmp, a >> 16, b >> 16, uint8_t, uint16_t); - result |= tmp << 32; - DO_MULL(tmp, a >> 24, b >> 24, uint8_t, uint16_t); - result |= tmp << 48; - return result; -} - -uint64_t HELPER(neon_mull_s8)(uint32_t a, uint32_t b) -{ - uint64_t tmp; - uint64_t result; - - DO_MULL(result, a, b, int8_t, uint16_t); - DO_MULL(tmp, a >> 8, b >> 8, int8_t, uint16_t); - result |= tmp << 16; - DO_MULL(tmp, a >> 16, b >> 16, int8_t, uint16_t); - result |= tmp << 32; - DO_MULL(tmp, a >> 24, b >> 24, int8_t, uint16_t); - result |= tmp << 48; - return result; -} - -uint64_t HELPER(neon_mull_u16)(uint32_t a, uint32_t b) -{ - uint64_t tmp; - uint64_t result; - - DO_MULL(result, a, b, uint16_t, uint32_t); - DO_MULL(tmp, a >> 16, b >> 16, uint16_t, uint32_t); - return result | (tmp << 32); -} - -uint64_t HELPER(neon_mull_s16)(uint32_t a, uint32_t b) -{ - uint64_t tmp; - uint64_t result; - - DO_MULL(result, a, b, int16_t, uint32_t); - DO_MULL(tmp, a >> 16, b >> 16, int16_t, uint32_t); - return result | (tmp << 32); -} - -uint64_t HELPER(neon_negl_u16)(uint64_t x) -{ - uint16_t tmp; - uint64_t result; - result = (uint16_t)-x; - tmp = -(x >> 16); - result |= (uint64_t)tmp << 16; - tmp = -(x >> 32); - result |= (uint64_t)tmp << 32; - tmp = -(x >> 48); - result |= (uint64_t)tmp << 48; - return result; -} - -#include -uint64_t HELPER(neon_negl_u32)(uint64_t x) -{ - uint32_t low = -x; - uint32_t high = -(x >> 32); - return low | ((uint64_t)high << 32); -} - -/* FIXME: There should be a native op for this. */ -uint64_t HELPER(neon_negl_u64)(uint64_t x) -{ - return -x; -} - -/* Saturnating sign manuipulation. */ -/* ??? Make these use NEON_VOP1 */ -#define DO_QABS8(x) do { \ - if (x == (int8_t)0x80) { \ - x = 0x7f; \ - SET_QC(); \ - } else if (x < 0) { \ - x = -x; \ - }} while (0) -uint32_t HELPER(neon_qabs_s8)(CPUState *env, uint32_t x) -{ - neon_s8 vec; - NEON_UNPACK(neon_s8, vec, x); - DO_QABS8(vec.v1); - DO_QABS8(vec.v2); - DO_QABS8(vec.v3); - DO_QABS8(vec.v4); - NEON_PACK(neon_s8, x, vec); - return x; -} -#undef DO_QABS8 - -#define DO_QNEG8(x) do { \ - if (x == (int8_t)0x80) { \ - x = 0x7f; \ - SET_QC(); \ - } else { \ - x = -x; \ - }} while (0) -uint32_t HELPER(neon_qneg_s8)(CPUState *env, uint32_t x) -{ - neon_s8 vec; - NEON_UNPACK(neon_s8, vec, x); - DO_QNEG8(vec.v1); - DO_QNEG8(vec.v2); - DO_QNEG8(vec.v3); - DO_QNEG8(vec.v4); - NEON_PACK(neon_s8, x, vec); - return x; -} -#undef DO_QNEG8 - -#define DO_QABS16(x) do { \ - if (x == (int16_t)0x8000) { \ - x = 0x7fff; \ - SET_QC(); \ - } else if (x < 0) { \ - x = -x; \ - }} while (0) -uint32_t HELPER(neon_qabs_s16)(CPUState *env, uint32_t x) -{ - neon_s16 vec; - NEON_UNPACK(neon_s16, vec, x); - DO_QABS16(vec.v1); - DO_QABS16(vec.v2); - NEON_PACK(neon_s16, x, vec); - return x; -} -#undef DO_QABS16 - -#define DO_QNEG16(x) do { \ - if (x == (int16_t)0x8000) { \ - x = 0x7fff; \ - SET_QC(); \ - } else { \ - x = -x; \ - }} while (0) -uint32_t HELPER(neon_qneg_s16)(CPUState *env, uint32_t x) -{ - neon_s16 vec; - NEON_UNPACK(neon_s16, vec, x); - DO_QNEG16(vec.v1); - DO_QNEG16(vec.v2); - NEON_PACK(neon_s16, x, vec); - return x; -} -#undef DO_QNEG16 - -uint32_t HELPER(neon_qabs_s32)(CPUState *env, uint32_t x) -{ - if (x == SIGNBIT) { - SET_QC(); - x = ~SIGNBIT; - } else if ((int32_t)x < 0) { - x = -x; - } - return x; -} - -uint32_t HELPER(neon_qneg_s32)(CPUState *env, uint32_t x) -{ - if (x == SIGNBIT) { - SET_QC(); - x = ~SIGNBIT; - } else { - x = -x; - } - return x; -} - -/* NEON Float helpers. */ -uint32_t HELPER(neon_min_f32)(uint32_t a, uint32_t b) -{ - float32 f0 = vfp_itos(a); - float32 f1 = vfp_itos(b); - return (float32_compare_quiet(f0, f1, NFS) == -1) ? a : b; -} - -uint32_t HELPER(neon_max_f32)(uint32_t a, uint32_t b) -{ - float32 f0 = vfp_itos(a); - float32 f1 = vfp_itos(b); - return (float32_compare_quiet(f0, f1, NFS) == 1) ? a : b; -} - -uint32_t HELPER(neon_abd_f32)(uint32_t a, uint32_t b) -{ - float32 f0 = vfp_itos(a); - float32 f1 = vfp_itos(b); - return vfp_stoi((float32_compare_quiet(f0, f1, NFS) == 1) - ? float32_sub(f0, f1, NFS) - : float32_sub(f1, f0, NFS)); -} - -uint32_t HELPER(neon_add_f32)(uint32_t a, uint32_t b) -{ - return vfp_stoi(float32_add(vfp_itos(a), vfp_itos(b), NFS)); -} - -uint32_t HELPER(neon_sub_f32)(uint32_t a, uint32_t b) -{ - return vfp_stoi(float32_sub(vfp_itos(a), vfp_itos(b), NFS)); -} - -uint32_t HELPER(neon_mul_f32)(uint32_t a, uint32_t b) -{ - return vfp_stoi(float32_mul(vfp_itos(a), vfp_itos(b), NFS)); -} - -/* Floating point comparisons produce an integer result. */ -#define NEON_VOP_FCMP(name, cmp) \ -uint32_t HELPER(neon_##name)(uint32_t a, uint32_t b) \ -{ \ - if (float32_compare_quiet(vfp_itos(a), vfp_itos(b), NFS) cmp 0) \ - return ~0; \ - else \ - return 0; \ -} - -NEON_VOP_FCMP(ceq_f32, ==) -NEON_VOP_FCMP(cge_f32, >=) -NEON_VOP_FCMP(cgt_f32, >) - -uint32_t HELPER(neon_acge_f32)(uint32_t a, uint32_t b) -{ - float32 f0 = float32_abs(vfp_itos(a)); - float32 f1 = float32_abs(vfp_itos(b)); - return (float32_compare_quiet(f0, f1,NFS) >= 0) ? ~0 : 0; -} - -uint32_t HELPER(neon_acgt_f32)(uint32_t a, uint32_t b) -{ - float32 f0 = float32_abs(vfp_itos(a)); - float32 f1 = float32_abs(vfp_itos(b)); - return (float32_compare_quiet(f0, f1, NFS) > 0) ? ~0 : 0; -} diff --git a/qemu/qemu-git/target-arm/.svn/text-base/op_addsub.h.svn-base b/qemu/qemu-git/target-arm/.svn/text-base/op_addsub.h.svn-base deleted file mode 100644 index 29f77ba..0000000 --- a/qemu/qemu-git/target-arm/.svn/text-base/op_addsub.h.svn-base +++ /dev/null @@ -1,103 +0,0 @@ -/* - * ARMv6 integer SIMD operations. - * - * Copyright (c) 2007 CodeSourcery. - * Written by Paul Brook - * - * This code is licenced under the GPL. - */ - -#ifdef ARITH_GE -#define GE_ARG , void *gep -#define DECLARE_GE uint32_t ge = 0 -#define SET_GE *(uint32_t *)gep = ge -#else -#define GE_ARG -#define DECLARE_GE do{}while(0) -#define SET_GE do{}while(0) -#endif - -#define RESULT(val, n, width) \ - res |= ((uint32_t)(glue(glue(uint,width),_t))(val)) << (n * width) - -uint32_t HELPER(glue(PFX,add16))(uint32_t a, uint32_t b GE_ARG) -{ - uint32_t res = 0; - DECLARE_GE; - - ADD16(a, b, 0); - ADD16(a >> 16, b >> 16, 1); - SET_GE; - return res; -} - -uint32_t HELPER(glue(PFX,add8))(uint32_t a, uint32_t b GE_ARG) -{ - uint32_t res = 0; - DECLARE_GE; - - ADD8(a, b, 0); - ADD8(a >> 8, b >> 8, 1); - ADD8(a >> 16, b >> 16, 2); - ADD8(a >> 24, b >> 24, 3); - SET_GE; - return res; -} - -uint32_t HELPER(glue(PFX,sub16))(uint32_t a, uint32_t b GE_ARG) -{ - uint32_t res = 0; - DECLARE_GE; - - SUB16(a, b, 0); - SUB16(a >> 16, b >> 16, 1); - SET_GE; - return res; -} - -uint32_t HELPER(glue(PFX,sub8))(uint32_t a, uint32_t b GE_ARG) -{ - uint32_t res = 0; - DECLARE_GE; - - SUB8(a, b, 0); - SUB8(a >> 8, b >> 8, 1); - SUB8(a >> 16, b >> 16, 2); - SUB8(a >> 24, b >> 24, 3); - SET_GE; - return res; -} - -uint32_t HELPER(glue(PFX,subaddx))(uint32_t a, uint32_t b GE_ARG) -{ - uint32_t res = 0; - DECLARE_GE; - - ADD16(a, b, 0); - SUB16(a >> 16, b >> 16, 1); - SET_GE; - return res; -} - -uint32_t HELPER(glue(PFX,addsubx))(uint32_t a, uint32_t b GE_ARG) -{ - uint32_t res = 0; - DECLARE_GE; - - SUB16(a, b, 0); - ADD16(a >> 16, b >> 16, 1); - SET_GE; - return res; -} - -#undef GE_ARG -#undef DECLARE_GE -#undef SET_GE -#undef RESULT - -#undef ARITH_GE -#undef PFX -#undef ADD16 -#undef SUB16 -#undef ADD8 -#undef SUB8 diff --git a/qemu/qemu-git/target-arm/.svn/text-base/op_helper.c.svn-base b/qemu/qemu-git/target-arm/.svn/text-base/op_helper.c.svn-base deleted file mode 100644 index 9b1a014..0000000 --- a/qemu/qemu-git/target-arm/.svn/text-base/op_helper.c.svn-base +++ /dev/null @@ -1,489 +0,0 @@ -/* - * ARM helper routines - * - * Copyright (c) 2005-2007 CodeSourcery, LLC - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library 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 - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, see . - */ -#include "exec.h" -#include "helpers.h" - -#define SIGNBIT (uint32_t)0x80000000 -#define SIGNBIT64 ((uint64_t)1 << 63) - -void raise_exception(int tt) -{ - env->exception_index = tt; - cpu_loop_exit(); -} - -/* thread support */ - -static spinlock_t global_cpu_lock = SPIN_LOCK_UNLOCKED; - -void cpu_lock(void) -{ - spin_lock(&global_cpu_lock); -} - -void cpu_unlock(void) -{ - spin_unlock(&global_cpu_lock); -} - -uint32_t HELPER(neon_tbl)(uint32_t ireg, uint32_t def, - uint32_t rn, uint32_t maxindex) -{ - uint32_t val; - uint32_t tmp; - int index; - int shift; - uint64_t *table; - table = (uint64_t *)&env->vfp.regs[rn]; - val = 0; - for (shift = 0; shift < 32; shift += 8) { - index = (ireg >> shift) & 0xff; - if (index < maxindex) { - tmp = (table[index >> 3] >> ((index & 7) << 3)) & 0xff; - val |= tmp << shift; - } else { - val |= def & (0xff << shift); - } - } - return val; -} - -#if !defined(CONFIG_USER_ONLY) - -#define MMUSUFFIX _mmu - -#define SHIFT 0 -#include "softmmu_template.h" - -#define SHIFT 1 -#include "softmmu_template.h" - -#define SHIFT 2 -#include "softmmu_template.h" - -#define SHIFT 3 -#include "softmmu_template.h" - -/* try to fill the TLB and return an exception if error. If retaddr is - NULL, it means that the function was called in C code (i.e. not - from generated code or from helper.c) */ -/* XXX: fix it to restore all registers */ -void tlb_fill (target_ulong addr, int is_write, int mmu_idx, void *retaddr) -{ - TranslationBlock *tb; - CPUState *saved_env; - unsigned long pc; - int ret; - - /* XXX: hack to restore env in all cases, even if not called from - generated code */ - saved_env = env; - env = cpu_single_env; - ret = cpu_arm_handle_mmu_fault(env, addr, is_write, mmu_idx, 1); - if (unlikely(ret)) { - if (retaddr) { - /* now we have a real cpu fault */ - pc = (unsigned long)retaddr; - tb = tb_find_pc(pc); - if (tb) { - /* the PC is inside the translated code. It means that we have - a virtual CPU fault */ - cpu_restore_state(tb, env, pc, NULL); - } - } - raise_exception(env->exception_index); - } - env = saved_env; -} -#endif - -/* FIXME: Pass an axplicit pointer to QF to CPUState, and move saturating - instructions into helper.c */ -uint32_t HELPER(add_setq)(uint32_t a, uint32_t b) -{ - uint32_t res = a + b; - if (((res ^ a) & SIGNBIT) && !((a ^ b) & SIGNBIT)) - env->QF = 1; - return res; -} - -uint32_t HELPER(add_saturate)(uint32_t a, uint32_t b) -{ - uint32_t res = a + b; - if (((res ^ a) & SIGNBIT) && !((a ^ b) & SIGNBIT)) { - env->QF = 1; - res = ~(((int32_t)a >> 31) ^ SIGNBIT); - } - return res; -} - -uint32_t HELPER(sub_saturate)(uint32_t a, uint32_t b) -{ - uint32_t res = a - b; - if (((res ^ a) & SIGNBIT) && ((a ^ b) & SIGNBIT)) { - env->QF = 1; - res = ~(((int32_t)a >> 31) ^ SIGNBIT); - } - return res; -} - -uint32_t HELPER(double_saturate)(int32_t val) -{ - uint32_t res; - if (val >= 0x40000000) { - res = ~SIGNBIT; - env->QF = 1; - } else if (val <= (int32_t)0xc0000000) { - res = SIGNBIT; - env->QF = 1; - } else { - res = val << 1; - } - return res; -} - -uint32_t HELPER(add_usaturate)(uint32_t a, uint32_t b) -{ - uint32_t res = a + b; - if (res < a) { - env->QF = 1; - res = ~0; - } - return res; -} - -uint32_t HELPER(sub_usaturate)(uint32_t a, uint32_t b) -{ - uint32_t res = a - b; - if (res > a) { - env->QF = 1; - res = 0; - } - return res; -} - -/* Signed saturation. */ -static inline uint32_t do_ssat(int32_t val, int shift) -{ - int32_t top; - uint32_t mask; - - top = val >> shift; - mask = (1u << shift) - 1; - if (top > 0) { - env->QF = 1; - return mask; - } else if (top < -1) { - env->QF = 1; - return ~mask; - } - return val; -} - -/* Unsigned saturation. */ -static inline uint32_t do_usat(int32_t val, int shift) -{ - uint32_t max; - - max = (1u << shift) - 1; - if (val < 0) { - env->QF = 1; - return 0; - } else if (val > max) { - env->QF = 1; - return max; - } - return val; -} - -/* Signed saturate. */ -uint32_t HELPER(ssat)(uint32_t x, uint32_t shift) -{ - return do_ssat(x, shift); -} - -/* Dual halfword signed saturate. */ -uint32_t HELPER(ssat16)(uint32_t x, uint32_t shift) -{ - uint32_t res; - - res = (uint16_t)do_ssat((int16_t)x, shift); - res |= do_ssat(((int32_t)x) >> 16, shift) << 16; - return res; -} - -/* Unsigned saturate. */ -uint32_t HELPER(usat)(uint32_t x, uint32_t shift) -{ - return do_usat(x, shift); -} - -/* Dual halfword unsigned saturate. */ -uint32_t HELPER(usat16)(uint32_t x, uint32_t shift) -{ - uint32_t res; - - res = (uint16_t)do_usat((int16_t)x, shift); - res |= do_usat(((int32_t)x) >> 16, shift) << 16; - return res; -} - -void HELPER(wfi)(void) -{ - env->exception_index = EXCP_HLT; - env->halted = 1; - cpu_loop_exit(); -} - -void HELPER(exception)(uint32_t excp) -{ - env->exception_index = excp; - cpu_loop_exit(); -} - -uint32_t HELPER(cpsr_read)(void) -{ - return cpsr_read(env) & ~CPSR_EXEC; -} - -void HELPER(cpsr_write)(uint32_t val, uint32_t mask) -{ - cpsr_write(env, val, mask); -} - -/* Access to user mode registers from privileged modes. */ -uint32_t HELPER(get_user_reg)(uint32_t regno) -{ - uint32_t val; - - if (regno == 13) { - val = env->banked_r13[0]; - } else if (regno == 14) { - val = env->banked_r14[0]; - } else if (regno >= 8 - && (env->uncached_cpsr & 0x1f) == ARM_CPU_MODE_FIQ) { - val = env->usr_regs[regno - 8]; - } else { - val = env->regs[regno]; - } - return val; -} - -void HELPER(set_user_reg)(uint32_t regno, uint32_t val) -{ - if (regno == 13) { - env->banked_r13[0] = val; - } else if (regno == 14) { - env->banked_r14[0] = val; - } else if (regno >= 8 - && (env->uncached_cpsr & 0x1f) == ARM_CPU_MODE_FIQ) { - env->usr_regs[regno - 8] = val; - } else { - env->regs[regno] = val; - } -} - -/* ??? Flag setting arithmetic is awkward because we need to do comparisons. - The only way to do that in TCG is a conditional branch, which clobbers - all our temporaries. For now implement these as helper functions. */ - -uint32_t HELPER (add_cc)(uint32_t a, uint32_t b) -{ - uint32_t result; - result = a + b; - env->NF = env->ZF = result; - env->CF = result < a; - env->VF = (a ^ b ^ -1) & (a ^ result); - return result; -} - -uint32_t HELPER(adc_cc)(uint32_t a, uint32_t b) -{ - uint32_t result; - if (!env->CF) { - result = a + b; - env->CF = result < a; - } else { - result = a + b + 1; - env->CF = result <= a; - } - env->VF = (a ^ b ^ -1) & (a ^ result); - env->NF = env->ZF = result; - return result; -} - -uint32_t HELPER(sub_cc)(uint32_t a, uint32_t b) -{ - uint32_t result; - result = a - b; - env->NF = env->ZF = result; - env->CF = a >= b; - env->VF = (a ^ b) & (a ^ result); - return result; -} - -uint32_t HELPER(sbc_cc)(uint32_t a, uint32_t b) -{ - uint32_t result; - if (!env->CF) { - result = a - b - 1; - env->CF = a > b; - } else { - result = a - b; - env->CF = a >= b; - } - env->VF = (a ^ b) & (a ^ result); - env->NF = env->ZF = result; - return result; -} - -/* Similarly for variable shift instructions. */ - -uint32_t HELPER(shl)(uint32_t x, uint32_t i) -{ - int shift = i & 0xff; - if (shift >= 32) - return 0; - return x << shift; -} - -uint32_t HELPER(shr)(uint32_t x, uint32_t i) -{ - int shift = i & 0xff; - if (shift >= 32) - return 0; - return (uint32_t)x >> shift; -} - -uint32_t HELPER(sar)(uint32_t x, uint32_t i) -{ - int shift = i & 0xff; - if (shift >= 32) - shift = 31; - return (int32_t)x >> shift; -} - -uint32_t HELPER(shl_cc)(uint32_t x, uint32_t i) -{ - int shift = i & 0xff; - if (shift >= 32) { - if (shift == 32) - env->CF = x & 1; - else - env->CF = 0; - return 0; - } else if (shift != 0) { - env->CF = (x >> (32 - shift)) & 1; - return x << shift; - } - return x; -} - -uint32_t HELPER(shr_cc)(uint32_t x, uint32_t i) -{ - int shift = i & 0xff; - if (shift >= 32) { - if (shift == 32) - env->CF = (x >> 31) & 1; - else - env->CF = 0; - return 0; - } else if (shift != 0) { - env->CF = (x >> (shift - 1)) & 1; - return x >> shift; - } - return x; -} - -uint32_t HELPER(sar_cc)(uint32_t x, uint32_t i) -{ - int shift = i & 0xff; - if (shift >= 32) { - env->CF = (x >> 31) & 1; - return (int32_t)x >> 31; - } else if (shift != 0) { - env->CF = (x >> (shift - 1)) & 1; - return (int32_t)x >> shift; - } - return x; -} - -uint32_t HELPER(ror_cc)(uint32_t x, uint32_t i) -{ - int shift1, shift; - shift1 = i & 0xff; - shift = shift1 & 0x1f; - if (shift == 0) { - if (shift1 != 0) - env->CF = (x >> 31) & 1; - return x; - } else { - env->CF = (x >> (shift - 1)) & 1; - return ((uint32_t)x >> shift) | (x << (32 - shift)); - } -} - -uint64_t HELPER(neon_add_saturate_s64)(uint64_t src1, uint64_t src2) -{ - uint64_t res; - - res = src1 + src2; - if (((res ^ src1) & SIGNBIT64) && !((src1 ^ src2) & SIGNBIT64)) { - env->QF = 1; - res = ((int64_t)src1 >> 63) ^ ~SIGNBIT64; - } - return res; -} - -uint64_t HELPER(neon_add_saturate_u64)(uint64_t src1, uint64_t src2) -{ - uint64_t res; - - res = src1 + src2; - if (res < src1) { - env->QF = 1; - res = ~(uint64_t)0; - } - return res; -} - -uint64_t HELPER(neon_sub_saturate_s64)(uint64_t src1, uint64_t src2) -{ - uint64_t res; - - res = src1 - src2; - if (((res ^ src1) & SIGNBIT64) && ((src1 ^ src2) & SIGNBIT64)) { - env->QF = 1; - res = ((int64_t)src1 >> 63) ^ ~SIGNBIT64; - } - return res; -} - -uint64_t HELPER(neon_sub_saturate_u64)(uint64_t src1, uint64_t src2) -{ - uint64_t res; - - if (src1 < src2) { - env->QF = 1; - res = 0; - } else { - res = src1 - src2; - } - return res; -} diff --git a/qemu/qemu-git/target-arm/.svn/text-base/translate.c.svn-base b/qemu/qemu-git/target-arm/.svn/text-base/translate.c.svn-base deleted file mode 100644 index 5cf3e06..0000000 --- a/qemu/qemu-git/target-arm/.svn/text-base/translate.c.svn-base +++ /dev/null @@ -1,9254 +0,0 @@ -/* - * ARM translation - * - * Copyright (c) 2003 Fabrice Bellard - * Copyright (c) 2005-2007 CodeSourcery - * Copyright (c) 2007 OpenedHand, Ltd. - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library 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 - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, see . - */ -#include -#include -#include -#include -#include - -#include "cpu.h" -#include "exec-all.h" -#include "disas.h" -#include "tcg-op.h" -#include "qemu-log.h" - -#include "helpers.h" -#define GEN_HELPER 1 -#include "helpers.h" - -#define ENABLE_ARCH_5J 0 -#define ENABLE_ARCH_6 arm_feature(env, ARM_FEATURE_V6) -#define ENABLE_ARCH_6K arm_feature(env, ARM_FEATURE_V6K) -#define ENABLE_ARCH_6T2 arm_feature(env, ARM_FEATURE_THUMB2) -#define ENABLE_ARCH_7 arm_feature(env, ARM_FEATURE_V7) - -#define ARCH(x) do { if (!ENABLE_ARCH_##x) goto illegal_op; } while(0) - -/* internal defines */ -typedef struct DisasContext { - target_ulong pc; - int is_jmp; - /* Nonzero if this instruction has been conditionally skipped. */ - int condjmp; - /* The label that will be jumped to when the instruction is skipped. */ - int condlabel; - /* Thumb-2 condtional execution bits. */ - int condexec_mask; - int condexec_cond; - struct TranslationBlock *tb; - int singlestep_enabled; - int thumb; -#if !defined(CONFIG_USER_ONLY) - int user; -#endif -} DisasContext; - -#if defined(CONFIG_USER_ONLY) -#define IS_USER(s) 1 -#else -#define IS_USER(s) (s->user) -#endif - -/* These instructions trap after executing, so defer them until after the - conditional executions state has been updated. */ -#define DISAS_WFI 4 -#define DISAS_SWI 5 - -static TCGv_ptr cpu_env; -/* We reuse the same 64-bit temporaries for efficiency. */ -static TCGv_i64 cpu_V0, cpu_V1, cpu_M0; -static TCGv_i32 cpu_R[16]; -static TCGv_i32 cpu_exclusive_addr; -static TCGv_i32 cpu_exclusive_val; -static TCGv_i32 cpu_exclusive_high; -#ifdef CONFIG_USER_ONLY -static TCGv_i32 cpu_exclusive_test; -static TCGv_i32 cpu_exclusive_info; -#endif - -/* FIXME: These should be removed. */ -static TCGv cpu_F0s, cpu_F1s; -static TCGv_i64 cpu_F0d, cpu_F1d; - -#include "gen-icount.h" - -static const char *regnames[] = - { "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7", - "r8", "r9", "r10", "r11", "r12", "r13", "r14", "pc" }; - -/* initialize TCG globals. */ -void arm_translate_init(void) -{ - int i; - - cpu_env = tcg_global_reg_new_ptr(TCG_AREG0, "env"); - - for (i = 0; i < 16; i++) { - cpu_R[i] = tcg_global_mem_new_i32(TCG_AREG0, - offsetof(CPUState, regs[i]), - regnames[i]); - } - cpu_exclusive_addr = tcg_global_mem_new_i32(TCG_AREG0, - offsetof(CPUState, exclusive_addr), "exclusive_addr"); - cpu_exclusive_val = tcg_global_mem_new_i32(TCG_AREG0, - offsetof(CPUState, exclusive_val), "exclusive_val"); - cpu_exclusive_high = tcg_global_mem_new_i32(TCG_AREG0, - offsetof(CPUState, exclusive_high), "exclusive_high"); -#ifdef CONFIG_USER_ONLY - cpu_exclusive_test = tcg_global_mem_new_i32(TCG_AREG0, - offsetof(CPUState, exclusive_test), "exclusive_test"); - cpu_exclusive_info = tcg_global_mem_new_i32(TCG_AREG0, - offsetof(CPUState, exclusive_info), "exclusive_info"); -#endif - -#define GEN_HELPER 2 -#include "helpers.h" -} - -static int num_temps; - -/* Allocate a temporary variable. */ -static TCGv_i32 new_tmp(void) -{ - num_temps++; - return tcg_temp_new_i32(); -} - -/* Release a temporary variable. */ -static void dead_tmp(TCGv tmp) -{ - tcg_temp_free(tmp); - num_temps--; -} - -static inline TCGv load_cpu_offset(int offset) -{ - TCGv tmp = new_tmp(); - tcg_gen_ld_i32(tmp, cpu_env, offset); - return tmp; -} - -#define load_cpu_field(name) load_cpu_offset(offsetof(CPUState, name)) - -static inline void store_cpu_offset(TCGv var, int offset) -{ - tcg_gen_st_i32(var, cpu_env, offset); - dead_tmp(var); -} - -#define store_cpu_field(var, name) \ - store_cpu_offset(var, offsetof(CPUState, name)) - -/* Set a variable to the value of a CPU register. */ -static void load_reg_var(DisasContext *s, TCGv var, int reg) -{ - if (reg == 15) { - uint32_t addr; - /* normaly, since we updated PC, we need only to add one insn */ - if (s->thumb) - addr = (long)s->pc + 2; - else - addr = (long)s->pc + 4; - tcg_gen_movi_i32(var, addr); - } else { - tcg_gen_mov_i32(var, cpu_R[reg]); - } -} - -/* Create a new temporary and set it to the value of a CPU register. */ -static inline TCGv load_reg(DisasContext *s, int reg) -{ - TCGv tmp = new_tmp(); - load_reg_var(s, tmp, reg); - return tmp; -} - -/* Set a CPU register. The source must be a temporary and will be - marked as dead. */ -static void store_reg(DisasContext *s, int reg, TCGv var) -{ - if (reg == 15) { - tcg_gen_andi_i32(var, var, ~1); - s->is_jmp = DISAS_JUMP; - } - tcg_gen_mov_i32(cpu_R[reg], var); - dead_tmp(var); -} - -/* Value extensions. */ -#define gen_uxtb(var) tcg_gen_ext8u_i32(var, var) -#define gen_uxth(var) tcg_gen_ext16u_i32(var, var) -#define gen_sxtb(var) tcg_gen_ext8s_i32(var, var) -#define gen_sxth(var) tcg_gen_ext16s_i32(var, var) - -#define gen_sxtb16(var) gen_helper_sxtb16(var, var) -#define gen_uxtb16(var) gen_helper_uxtb16(var, var) - - -static inline void gen_set_cpsr(TCGv var, uint32_t mask) -{ - TCGv tmp_mask = tcg_const_i32(mask); - gen_helper_cpsr_write(var, tmp_mask); - tcg_temp_free_i32(tmp_mask); -} -/* Set NZCV flags from the high 4 bits of var. */ -#define gen_set_nzcv(var) gen_set_cpsr(var, CPSR_NZCV) - -static void gen_exception(int excp) -{ - TCGv tmp = new_tmp(); - tcg_gen_movi_i32(tmp, excp); - gen_helper_exception(tmp); - dead_tmp(tmp); -} - -static void gen_smul_dual(TCGv a, TCGv b) -{ - TCGv tmp1 = new_tmp(); - TCGv tmp2 = new_tmp(); - tcg_gen_ext16s_i32(tmp1, a); - tcg_gen_ext16s_i32(tmp2, b); - tcg_gen_mul_i32(tmp1, tmp1, tmp2); - dead_tmp(tmp2); - tcg_gen_sari_i32(a, a, 16); - tcg_gen_sari_i32(b, b, 16); - tcg_gen_mul_i32(b, b, a); - tcg_gen_mov_i32(a, tmp1); - dead_tmp(tmp1); -} - -/* Byteswap each halfword. */ -static void gen_rev16(TCGv var) -{ - TCGv tmp = new_tmp(); - tcg_gen_shri_i32(tmp, var, 8); - tcg_gen_andi_i32(tmp, tmp, 0x00ff00ff); - tcg_gen_shli_i32(var, var, 8); - tcg_gen_andi_i32(var, var, 0xff00ff00); - tcg_gen_or_i32(var, var, tmp); - dead_tmp(tmp); -} - -/* Byteswap low halfword and sign extend. */ -static void gen_revsh(TCGv var) -{ - TCGv tmp = new_tmp(); - tcg_gen_shri_i32(tmp, var, 8); - tcg_gen_andi_i32(tmp, tmp, 0x00ff); - tcg_gen_shli_i32(var, var, 8); - tcg_gen_ext8s_i32(var, var); - tcg_gen_or_i32(var, var, tmp); - dead_tmp(tmp); -} - -/* Unsigned bitfield extract. */ -static void gen_ubfx(TCGv var, int shift, uint32_t mask) -{ - if (shift) - tcg_gen_shri_i32(var, var, shift); - tcg_gen_andi_i32(var, var, mask); -} - -/* Signed bitfield extract. */ -static void gen_sbfx(TCGv var, int shift, int width) -{ - uint32_t signbit; - - if (shift) - tcg_gen_sari_i32(var, var, shift); - if (shift + width < 32) { - signbit = 1u << (width - 1); - tcg_gen_andi_i32(var, var, (1u << width) - 1); - tcg_gen_xori_i32(var, var, signbit); - tcg_gen_subi_i32(var, var, signbit); - } -} - -/* Bitfield insertion. Insert val into base. Clobbers base and val. */ -static void gen_bfi(TCGv dest, TCGv base, TCGv val, int shift, uint32_t mask) -{ - tcg_gen_andi_i32(val, val, mask); - tcg_gen_shli_i32(val, val, shift); - tcg_gen_andi_i32(base, base, ~(mask << shift)); - tcg_gen_or_i32(dest, base, val); -} - -/* Round the top 32 bits of a 64-bit value. */ -static void gen_roundqd(TCGv a, TCGv b) -{ - tcg_gen_shri_i32(a, a, 31); - tcg_gen_add_i32(a, a, b); -} - -/* FIXME: Most targets have native widening multiplication. - It would be good to use that instead of a full wide multiply. */ -/* 32x32->64 multiply. Marks inputs as dead. */ -static TCGv_i64 gen_mulu_i64_i32(TCGv a, TCGv b) -{ - TCGv_i64 tmp1 = tcg_temp_new_i64(); - TCGv_i64 tmp2 = tcg_temp_new_i64(); - - tcg_gen_extu_i32_i64(tmp1, a); - dead_tmp(a); - tcg_gen_extu_i32_i64(tmp2, b); - dead_tmp(b); - tcg_gen_mul_i64(tmp1, tmp1, tmp2); - tcg_temp_free_i64(tmp2); - return tmp1; -} - -static TCGv_i64 gen_muls_i64_i32(TCGv a, TCGv b) -{ - TCGv_i64 tmp1 = tcg_temp_new_i64(); - TCGv_i64 tmp2 = tcg_temp_new_i64(); - - tcg_gen_ext_i32_i64(tmp1, a); - dead_tmp(a); - tcg_gen_ext_i32_i64(tmp2, b); - dead_tmp(b); - tcg_gen_mul_i64(tmp1, tmp1, tmp2); - tcg_temp_free_i64(tmp2); - return tmp1; -} - -/* Signed 32x32->64 multiply. */ -static void gen_imull(TCGv a, TCGv b) -{ - TCGv_i64 tmp1 = tcg_temp_new_i64(); - TCGv_i64 tmp2 = tcg_temp_new_i64(); - - tcg_gen_ext_i32_i64(tmp1, a); - tcg_gen_ext_i32_i64(tmp2, b); - tcg_gen_mul_i64(tmp1, tmp1, tmp2); - tcg_temp_free_i64(tmp2); - tcg_gen_trunc_i64_i32(a, tmp1); - tcg_gen_shri_i64(tmp1, tmp1, 32); - tcg_gen_trunc_i64_i32(b, tmp1); - tcg_temp_free_i64(tmp1); -} - -/* Swap low and high halfwords. */ -static void gen_swap_half(TCGv var) -{ - TCGv tmp = new_tmp(); - tcg_gen_shri_i32(tmp, var, 16); - tcg_gen_shli_i32(var, var, 16); - tcg_gen_or_i32(var, var, tmp); - dead_tmp(tmp); -} - -/* Dual 16-bit add. Result placed in t0 and t1 is marked as dead. - tmp = (t0 ^ t1) & 0x8000; - t0 &= ~0x8000; - t1 &= ~0x8000; - t0 = (t0 + t1) ^ tmp; - */ - -static void gen_add16(TCGv t0, TCGv t1) -{ - TCGv tmp = new_tmp(); - tcg_gen_xor_i32(tmp, t0, t1); - tcg_gen_andi_i32(tmp, tmp, 0x8000); - tcg_gen_andi_i32(t0, t0, ~0x8000); - tcg_gen_andi_i32(t1, t1, ~0x8000); - tcg_gen_add_i32(t0, t0, t1); - tcg_gen_xor_i32(t0, t0, tmp); - dead_tmp(tmp); - dead_tmp(t1); -} - -#define gen_set_CF(var) tcg_gen_st_i32(var, cpu_env, offsetof(CPUState, CF)) - -/* Set CF to the top bit of var. */ -static void gen_set_CF_bit31(TCGv var) -{ - TCGv tmp = new_tmp(); - tcg_gen_shri_i32(tmp, var, 31); - gen_set_CF(tmp); - dead_tmp(tmp); -} - -/* Set N and Z flags from var. */ -static inline void gen_logic_CC(TCGv var) -{ - tcg_gen_st_i32(var, cpu_env, offsetof(CPUState, NF)); - tcg_gen_st_i32(var, cpu_env, offsetof(CPUState, ZF)); -} - -/* T0 += T1 + CF. */ -static void gen_adc(TCGv t0, TCGv t1) -{ - TCGv tmp; - tcg_gen_add_i32(t0, t0, t1); - tmp = load_cpu_field(CF); - tcg_gen_add_i32(t0, t0, tmp); - dead_tmp(tmp); -} - -/* dest = T0 + T1 + CF. */ -static void gen_add_carry(TCGv dest, TCGv t0, TCGv t1) -{ - TCGv tmp; - tcg_gen_add_i32(dest, t0, t1); - tmp = load_cpu_field(CF); - tcg_gen_add_i32(dest, dest, tmp); - dead_tmp(tmp); -} - -/* dest = T0 - T1 + CF - 1. */ -static void gen_sub_carry(TCGv dest, TCGv t0, TCGv t1) -{ - TCGv tmp; - tcg_gen_sub_i32(dest, t0, t1); - tmp = load_cpu_field(CF); - tcg_gen_add_i32(dest, dest, tmp); - tcg_gen_subi_i32(dest, dest, 1); - dead_tmp(tmp); -} - -/* FIXME: Implement this natively. */ -#define tcg_gen_abs_i32(t0, t1) gen_helper_abs(t0, t1) - -static void shifter_out_im(TCGv var, int shift) -{ - TCGv tmp = new_tmp(); - if (shift == 0) { - tcg_gen_andi_i32(tmp, var, 1); - } else { - tcg_gen_shri_i32(tmp, var, shift); - if (shift != 31) - tcg_gen_andi_i32(tmp, tmp, 1); - } - gen_set_CF(tmp); - dead_tmp(tmp); -} - -/* Shift by immediate. Includes special handling for shift == 0. */ -static inline void gen_arm_shift_im(TCGv var, int shiftop, int shift, int flags) -{ - switch (shiftop) { - case 0: /* LSL */ - if (shift != 0) { - if (flags) - shifter_out_im(var, 32 - shift); - tcg_gen_shli_i32(var, var, shift); - } - break; - case 1: /* LSR */ - if (shift == 0) { - if (flags) { - tcg_gen_shri_i32(var, var, 31); - gen_set_CF(var); - } - tcg_gen_movi_i32(var, 0); - } else { - if (flags) - shifter_out_im(var, shift - 1); - tcg_gen_shri_i32(var, var, shift); - } - break; - case 2: /* ASR */ - if (shift == 0) - shift = 32; - if (flags) - shifter_out_im(var, shift - 1); - if (shift == 32) - shift = 31; - tcg_gen_sari_i32(var, var, shift); - break; - case 3: /* ROR/RRX */ - if (shift != 0) { - if (flags) - shifter_out_im(var, shift - 1); - tcg_gen_rotri_i32(var, var, shift); break; - } else { - TCGv tmp = load_cpu_field(CF); - if (flags) - shifter_out_im(var, 0); - tcg_gen_shri_i32(var, var, 1); - tcg_gen_shli_i32(tmp, tmp, 31); - tcg_gen_or_i32(var, var, tmp); - dead_tmp(tmp); - } - } -}; - -static inline void gen_arm_shift_reg(TCGv var, int shiftop, - TCGv shift, int flags) -{ - if (flags) { - switch (shiftop) { - case 0: gen_helper_shl_cc(var, var, shift); break; - case 1: gen_helper_shr_cc(var, var, shift); break; - case 2: gen_helper_sar_cc(var, var, shift); break; - case 3: gen_helper_ror_cc(var, var, shift); break; - } - } else { - switch (shiftop) { - case 0: gen_helper_shl(var, var, shift); break; - case 1: gen_helper_shr(var, var, shift); break; - case 2: gen_helper_sar(var, var, shift); break; - case 3: tcg_gen_andi_i32(shift, shift, 0x1f); - tcg_gen_rotr_i32(var, var, shift); break; - } - } - dead_tmp(shift); -} - -#define PAS_OP(pfx) \ - switch (op2) { \ - case 0: gen_pas_helper(glue(pfx,add16)); break; \ - case 1: gen_pas_helper(glue(pfx,addsubx)); break; \ - case 2: gen_pas_helper(glue(pfx,subaddx)); break; \ - case 3: gen_pas_helper(glue(pfx,sub16)); break; \ - case 4: gen_pas_helper(glue(pfx,add8)); break; \ - case 7: gen_pas_helper(glue(pfx,sub8)); break; \ - } -static void gen_arm_parallel_addsub(int op1, int op2, TCGv a, TCGv b) -{ - TCGv_ptr tmp; - - switch (op1) { -#define gen_pas_helper(name) glue(gen_helper_,name)(a, a, b, tmp) - case 1: - tmp = tcg_temp_new_ptr(); - tcg_gen_addi_ptr(tmp, cpu_env, offsetof(CPUState, GE)); - PAS_OP(s) - tcg_temp_free_ptr(tmp); - break; - case 5: - tmp = tcg_temp_new_ptr(); - tcg_gen_addi_ptr(tmp, cpu_env, offsetof(CPUState, GE)); - PAS_OP(u) - tcg_temp_free_ptr(tmp); - break; -#undef gen_pas_helper -#define gen_pas_helper(name) glue(gen_helper_,name)(a, a, b) - case 2: - PAS_OP(q); - break; - case 3: - PAS_OP(sh); - break; - case 6: - PAS_OP(uq); - break; - case 7: - PAS_OP(uh); - break; -#undef gen_pas_helper - } -} -#undef PAS_OP - -/* For unknown reasons Arm and Thumb-2 use arbitrarily different encodings. */ -#define PAS_OP(pfx) \ - switch (op2) { \ - case 0: gen_pas_helper(glue(pfx,add8)); break; \ - case 1: gen_pas_helper(glue(pfx,add16)); break; \ - case 2: gen_pas_helper(glue(pfx,addsubx)); break; \ - case 4: gen_pas_helper(glue(pfx,sub8)); break; \ - case 5: gen_pas_helper(glue(pfx,sub16)); break; \ - case 6: gen_pas_helper(glue(pfx,subaddx)); break; \ - } -static void gen_thumb2_parallel_addsub(int op1, int op2, TCGv a, TCGv b) -{ - TCGv_ptr tmp; - - switch (op1) { -#define gen_pas_helper(name) glue(gen_helper_,name)(a, a, b, tmp) - case 0: - tmp = tcg_temp_new_ptr(); - tcg_gen_addi_ptr(tmp, cpu_env, offsetof(CPUState, GE)); - PAS_OP(s) - tcg_temp_free_ptr(tmp); - break; - case 4: - tmp = tcg_temp_new_ptr(); - tcg_gen_addi_ptr(tmp, cpu_env, offsetof(CPUState, GE)); - PAS_OP(u) - tcg_temp_free_ptr(tmp); - break; -#undef gen_pas_helper -#define gen_pas_helper(name) glue(gen_helper_,name)(a, a, b) - case 1: - PAS_OP(q); - break; - case 2: - PAS_OP(sh); - break; - case 5: - PAS_OP(uq); - break; - case 6: - PAS_OP(uh); - break; -#undef gen_pas_helper - } -} -#undef PAS_OP - -static void gen_test_cc(int cc, int label) -{ - TCGv tmp; - TCGv tmp2; - int inv; - - switch (cc) { - case 0: /* eq: Z */ - tmp = load_cpu_field(ZF); - tcg_gen_brcondi_i32(TCG_COND_EQ, tmp, 0, label); - break; - case 1: /* ne: !Z */ - tmp = load_cpu_field(ZF); - tcg_gen_brcondi_i32(TCG_COND_NE, tmp, 0, label); - break; - case 2: /* cs: C */ - tmp = load_cpu_field(CF); - tcg_gen_brcondi_i32(TCG_COND_NE, tmp, 0, label); - break; - case 3: /* cc: !C */ - tmp = load_cpu_field(CF); - tcg_gen_brcondi_i32(TCG_COND_EQ, tmp, 0, label); - break; - case 4: /* mi: N */ - tmp = load_cpu_field(NF); - tcg_gen_brcondi_i32(TCG_COND_LT, tmp, 0, label); - break; - case 5: /* pl: !N */ - tmp = load_cpu_field(NF); - tcg_gen_brcondi_i32(TCG_COND_GE, tmp, 0, label); - break; - case 6: /* vs: V */ - tmp = load_cpu_field(VF); - tcg_gen_brcondi_i32(TCG_COND_LT, tmp, 0, label); - break; - case 7: /* vc: !V */ - tmp = load_cpu_field(VF); - tcg_gen_brcondi_i32(TCG_COND_GE, tmp, 0, label); - break; - case 8: /* hi: C && !Z */ - inv = gen_new_label(); - tmp = load_cpu_field(CF); - tcg_gen_brcondi_i32(TCG_COND_EQ, tmp, 0, inv); - dead_tmp(tmp); - tmp = load_cpu_field(ZF); - tcg_gen_brcondi_i32(TCG_COND_NE, tmp, 0, label); - gen_set_label(inv); - break; - case 9: /* ls: !C || Z */ - tmp = load_cpu_field(CF); - tcg_gen_brcondi_i32(TCG_COND_EQ, tmp, 0, label); - dead_tmp(tmp); - tmp = load_cpu_field(ZF); - tcg_gen_brcondi_i32(TCG_COND_EQ, tmp, 0, label); - break; - case 10: /* ge: N == V -> N ^ V == 0 */ - tmp = load_cpu_field(VF); - tmp2 = load_cpu_field(NF); - tcg_gen_xor_i32(tmp, tmp, tmp2); - dead_tmp(tmp2); - tcg_gen_brcondi_i32(TCG_COND_GE, tmp, 0, label); - break; - case 11: /* lt: N != V -> N ^ V != 0 */ - tmp = load_cpu_field(VF); - tmp2 = load_cpu_field(NF); - tcg_gen_xor_i32(tmp, tmp, tmp2); - dead_tmp(tmp2); - tcg_gen_brcondi_i32(TCG_COND_LT, tmp, 0, label); - break; - case 12: /* gt: !Z && N == V */ - inv = gen_new_label(); - tmp = load_cpu_field(ZF); - tcg_gen_brcondi_i32(TCG_COND_EQ, tmp, 0, inv); - dead_tmp(tmp); - tmp = load_cpu_field(VF); - tmp2 = load_cpu_field(NF); - tcg_gen_xor_i32(tmp, tmp, tmp2); - dead_tmp(tmp2); - tcg_gen_brcondi_i32(TCG_COND_GE, tmp, 0, label); - gen_set_label(inv); - break; - case 13: /* le: Z || N != V */ - tmp = load_cpu_field(ZF); - tcg_gen_brcondi_i32(TCG_COND_EQ, tmp, 0, label); - dead_tmp(tmp); - tmp = load_cpu_field(VF); - tmp2 = load_cpu_field(NF); - tcg_gen_xor_i32(tmp, tmp, tmp2); - dead_tmp(tmp2); - tcg_gen_brcondi_i32(TCG_COND_LT, tmp, 0, label); - break; - default: - fprintf(stderr, "Bad condition code 0x%x\n", cc); - abort(); - } - dead_tmp(tmp); -} - -static const uint8_t table_logic_cc[16] = { - 1, /* and */ - 1, /* xor */ - 0, /* sub */ - 0, /* rsb */ - 0, /* add */ - 0, /* adc */ - 0, /* sbc */ - 0, /* rsc */ - 1, /* andl */ - 1, /* xorl */ - 0, /* cmp */ - 0, /* cmn */ - 1, /* orr */ - 1, /* mov */ - 1, /* bic */ - 1, /* mvn */ -}; - -/* Set PC and Thumb state from an immediate address. */ -static inline void gen_bx_im(DisasContext *s, uint32_t addr) -{ - TCGv tmp; - - s->is_jmp = DISAS_UPDATE; - if (s->thumb != (addr & 1)) { - tmp = new_tmp(); - tcg_gen_movi_i32(tmp, addr & 1); - tcg_gen_st_i32(tmp, cpu_env, offsetof(CPUState, thumb)); - dead_tmp(tmp); - } - tcg_gen_movi_i32(cpu_R[15], addr & ~1); -} - -/* Set PC and Thumb state from var. var is marked as dead. */ -static inline void gen_bx(DisasContext *s, TCGv var) -{ - s->is_jmp = DISAS_UPDATE; - tcg_gen_andi_i32(cpu_R[15], var, ~1); - tcg_gen_andi_i32(var, var, 1); - store_cpu_field(var, thumb); -} - -/* Variant of store_reg which uses branch&exchange logic when storing - to r15 in ARM architecture v7 and above. The source must be a temporary - and will be marked as dead. */ -static inline void store_reg_bx(CPUState *env, DisasContext *s, - int reg, TCGv var) -{ - if (reg == 15 && ENABLE_ARCH_7) { - gen_bx(s, var); - } else { - store_reg(s, reg, var); - } -} - -static inline TCGv gen_ld8s(TCGv addr, int index) -{ - TCGv tmp = new_tmp(); - tcg_gen_qemu_ld8s(tmp, addr, index); - return tmp; -} -static inline TCGv gen_ld8u(TCGv addr, int index) -{ - TCGv tmp = new_tmp(); - tcg_gen_qemu_ld8u(tmp, addr, index); - return tmp; -} -static inline TCGv gen_ld16s(TCGv addr, int index) -{ - TCGv tmp = new_tmp(); - tcg_gen_qemu_ld16s(tmp, addr, index); - return tmp; -} -static inline TCGv gen_ld16u(TCGv addr, int index) -{ - TCGv tmp = new_tmp(); - tcg_gen_qemu_ld16u(tmp, addr, index); - return tmp; -} -static inline TCGv gen_ld32(TCGv addr, int index) -{ - TCGv tmp = new_tmp(); - tcg_gen_qemu_ld32u(tmp, addr, index); - return tmp; -} -static inline TCGv_i64 gen_ld64(TCGv addr, int index) -{ - TCGv_i64 tmp = tcg_temp_new_i64(); - tcg_gen_qemu_ld64(tmp, addr, index); - return tmp; -} -static inline void gen_st8(TCGv val, TCGv addr, int index) -{ - tcg_gen_qemu_st8(val, addr, index); - dead_tmp(val); -} -static inline void gen_st16(TCGv val, TCGv addr, int index) -{ - tcg_gen_qemu_st16(val, addr, index); - dead_tmp(val); -} -static inline void gen_st32(TCGv val, TCGv addr, int index) -{ - tcg_gen_qemu_st32(val, addr, index); - dead_tmp(val); -} -static inline void gen_st64(TCGv_i64 val, TCGv addr, int index) -{ - tcg_gen_qemu_st64(val, addr, index); - tcg_temp_free_i64(val); -} - -static inline void gen_set_pc_im(uint32_t val) -{ - tcg_gen_movi_i32(cpu_R[15], val); -} - -/* Force a TB lookup after an instruction that changes the CPU state. */ -static inline void gen_lookup_tb(DisasContext *s) -{ - tcg_gen_movi_i32(cpu_R[15], s->pc & ~1); - s->is_jmp = DISAS_UPDATE; -} - -static inline void gen_add_data_offset(DisasContext *s, unsigned int insn, - TCGv var) -{ - int val, rm, shift, shiftop; - TCGv offset; - - if (!(insn & (1 << 25))) { - /* immediate */ - val = insn & 0xfff; - if (!(insn & (1 << 23))) - val = -val; - if (val != 0) - tcg_gen_addi_i32(var, var, val); - } else { - /* shift/register */ - rm = (insn) & 0xf; - shift = (insn >> 7) & 0x1f; - shiftop = (insn >> 5) & 3; - offset = load_reg(s, rm); - gen_arm_shift_im(offset, shiftop, shift, 0); - if (!(insn & (1 << 23))) - tcg_gen_sub_i32(var, var, offset); - else - tcg_gen_add_i32(var, var, offset); - dead_tmp(offset); - } -} - -static inline void gen_add_datah_offset(DisasContext *s, unsigned int insn, - int extra, TCGv var) -{ - int val, rm; - TCGv offset; - - if (insn & (1 << 22)) { - /* immediate */ - val = (insn & 0xf) | ((insn >> 4) & 0xf0); - if (!(insn & (1 << 23))) - val = -val; - val += extra; - if (val != 0) - tcg_gen_addi_i32(var, var, val); - } else { - /* register */ - if (extra) - tcg_gen_addi_i32(var, var, extra); - rm = (insn) & 0xf; - offset = load_reg(s, rm); - if (!(insn & (1 << 23))) - tcg_gen_sub_i32(var, var, offset); - else - tcg_gen_add_i32(var, var, offset); - dead_tmp(offset); - } -} - -#define VFP_OP2(name) \ -static inline void gen_vfp_##name(int dp) \ -{ \ - if (dp) \ - gen_helper_vfp_##name##d(cpu_F0d, cpu_F0d, cpu_F1d, cpu_env); \ - else \ - gen_helper_vfp_##name##s(cpu_F0s, cpu_F0s, cpu_F1s, cpu_env); \ -} - -VFP_OP2(add) -VFP_OP2(sub) -VFP_OP2(mul) -VFP_OP2(div) - -#undef VFP_OP2 - -static inline void gen_vfp_abs(int dp) -{ - if (dp) - gen_helper_vfp_absd(cpu_F0d, cpu_F0d); - else - gen_helper_vfp_abss(cpu_F0s, cpu_F0s); -} - -static inline void gen_vfp_neg(int dp) -{ - if (dp) - gen_helper_vfp_negd(cpu_F0d, cpu_F0d); - else - gen_helper_vfp_negs(cpu_F0s, cpu_F0s); -} - -static inline void gen_vfp_sqrt(int dp) -{ - if (dp) - gen_helper_vfp_sqrtd(cpu_F0d, cpu_F0d, cpu_env); - else - gen_helper_vfp_sqrts(cpu_F0s, cpu_F0s, cpu_env); -} - -static inline void gen_vfp_cmp(int dp) -{ - if (dp) - gen_helper_vfp_cmpd(cpu_F0d, cpu_F1d, cpu_env); - else - gen_helper_vfp_cmps(cpu_F0s, cpu_F1s, cpu_env); -} - -static inline void gen_vfp_cmpe(int dp) -{ - if (dp) - gen_helper_vfp_cmped(cpu_F0d, cpu_F1d, cpu_env); - else - gen_helper_vfp_cmpes(cpu_F0s, cpu_F1s, cpu_env); -} - -static inline void gen_vfp_F1_ld0(int dp) -{ - if (dp) - tcg_gen_movi_i64(cpu_F1d, 0); - else - tcg_gen_movi_i32(cpu_F1s, 0); -} - -static inline void gen_vfp_uito(int dp) -{ - if (dp) - gen_helper_vfp_uitod(cpu_F0d, cpu_F0s, cpu_env); - else - gen_helper_vfp_uitos(cpu_F0s, cpu_F0s, cpu_env); -} - -static inline void gen_vfp_sito(int dp) -{ - if (dp) - gen_helper_vfp_sitod(cpu_F0d, cpu_F0s, cpu_env); - else - gen_helper_vfp_sitos(cpu_F0s, cpu_F0s, cpu_env); -} - -static inline void gen_vfp_toui(int dp) -{ - if (dp) - gen_helper_vfp_touid(cpu_F0s, cpu_F0d, cpu_env); - else - gen_helper_vfp_touis(cpu_F0s, cpu_F0s, cpu_env); -} - -static inline void gen_vfp_touiz(int dp) -{ - if (dp) - gen_helper_vfp_touizd(cpu_F0s, cpu_F0d, cpu_env); - else - gen_helper_vfp_touizs(cpu_F0s, cpu_F0s, cpu_env); -} - -static inline void gen_vfp_tosi(int dp) -{ - if (dp) - gen_helper_vfp_tosid(cpu_F0s, cpu_F0d, cpu_env); - else - gen_helper_vfp_tosis(cpu_F0s, cpu_F0s, cpu_env); -} - -static inline void gen_vfp_tosiz(int dp) -{ - if (dp) - gen_helper_vfp_tosizd(cpu_F0s, cpu_F0d, cpu_env); - else - gen_helper_vfp_tosizs(cpu_F0s, cpu_F0s, cpu_env); -} - -#define VFP_GEN_FIX(name) \ -static inline void gen_vfp_##name(int dp, int shift) \ -{ \ - TCGv tmp_shift = tcg_const_i32(shift); \ - if (dp) \ - gen_helper_vfp_##name##d(cpu_F0d, cpu_F0d, tmp_shift, cpu_env);\ - else \ - gen_helper_vfp_##name##s(cpu_F0s, cpu_F0s, tmp_shift, cpu_env);\ - tcg_temp_free_i32(tmp_shift); \ -} -VFP_GEN_FIX(tosh) -VFP_GEN_FIX(tosl) -VFP_GEN_FIX(touh) -VFP_GEN_FIX(toul) -VFP_GEN_FIX(shto) -VFP_GEN_FIX(slto) -VFP_GEN_FIX(uhto) -VFP_GEN_FIX(ulto) -#undef VFP_GEN_FIX - -static inline void gen_vfp_ld(DisasContext *s, int dp, TCGv addr) -{ - if (dp) - tcg_gen_qemu_ld64(cpu_F0d, addr, IS_USER(s)); - else - tcg_gen_qemu_ld32u(cpu_F0s, addr, IS_USER(s)); -} - -static inline void gen_vfp_st(DisasContext *s, int dp, TCGv addr) -{ - if (dp) - tcg_gen_qemu_st64(cpu_F0d, addr, IS_USER(s)); - else - tcg_gen_qemu_st32(cpu_F0s, addr, IS_USER(s)); -} - -static inline long -vfp_reg_offset (int dp, int reg) -{ - if (dp) - return offsetof(CPUARMState, vfp.regs[reg]); - else if (reg & 1) { - return offsetof(CPUARMState, vfp.regs[reg >> 1]) - + offsetof(CPU_DoubleU, l.upper); - } else { - return offsetof(CPUARMState, vfp.regs[reg >> 1]) - + offsetof(CPU_DoubleU, l.lower); - } -} - -/* Return the offset of a 32-bit piece of a NEON register. - zero is the least significant end of the register. */ -static inline long -neon_reg_offset (int reg, int n) -{ - int sreg; - sreg = reg * 2 + n; - return vfp_reg_offset(0, sreg); -} - -static TCGv neon_load_reg(int reg, int pass) -{ - TCGv tmp = new_tmp(); - tcg_gen_ld_i32(tmp, cpu_env, neon_reg_offset(reg, pass)); - return tmp; -} - -static void neon_store_reg(int reg, int pass, TCGv var) -{ - tcg_gen_st_i32(var, cpu_env, neon_reg_offset(reg, pass)); - dead_tmp(var); -} - -static inline void neon_load_reg64(TCGv_i64 var, int reg) -{ - tcg_gen_ld_i64(var, cpu_env, vfp_reg_offset(1, reg)); -} - -static inline void neon_store_reg64(TCGv_i64 var, int reg) -{ - tcg_gen_st_i64(var, cpu_env, vfp_reg_offset(1, reg)); -} - -#define tcg_gen_ld_f32 tcg_gen_ld_i32 -#define tcg_gen_ld_f64 tcg_gen_ld_i64 -#define tcg_gen_st_f32 tcg_gen_st_i32 -#define tcg_gen_st_f64 tcg_gen_st_i64 - -static inline void gen_mov_F0_vreg(int dp, int reg) -{ - if (dp) - tcg_gen_ld_f64(cpu_F0d, cpu_env, vfp_reg_offset(dp, reg)); - else - tcg_gen_ld_f32(cpu_F0s, cpu_env, vfp_reg_offset(dp, reg)); -} - -static inline void gen_mov_F1_vreg(int dp, int reg) -{ - if (dp) - tcg_gen_ld_f64(cpu_F1d, cpu_env, vfp_reg_offset(dp, reg)); - else - tcg_gen_ld_f32(cpu_F1s, cpu_env, vfp_reg_offset(dp, reg)); -} - -static inline void gen_mov_vreg_F0(int dp, int reg) -{ - if (dp) - tcg_gen_st_f64(cpu_F0d, cpu_env, vfp_reg_offset(dp, reg)); - else - tcg_gen_st_f32(cpu_F0s, cpu_env, vfp_reg_offset(dp, reg)); -} - -#define ARM_CP_RW_BIT (1 << 20) - -static inline void iwmmxt_load_reg(TCGv_i64 var, int reg) -{ - tcg_gen_ld_i64(var, cpu_env, offsetof(CPUState, iwmmxt.regs[reg])); -} - -static inline void iwmmxt_store_reg(TCGv_i64 var, int reg) -{ - tcg_gen_st_i64(var, cpu_env, offsetof(CPUState, iwmmxt.regs[reg])); -} - -static inline TCGv iwmmxt_load_creg(int reg) -{ - TCGv var = new_tmp(); - tcg_gen_ld_i32(var, cpu_env, offsetof(CPUState, iwmmxt.cregs[reg])); - return var; -} - -static inline void iwmmxt_store_creg(int reg, TCGv var) -{ - tcg_gen_st_i32(var, cpu_env, offsetof(CPUState, iwmmxt.cregs[reg])); -} - -static inline void gen_op_iwmmxt_movq_wRn_M0(int rn) -{ - iwmmxt_store_reg(cpu_M0, rn); -} - -static inline void gen_op_iwmmxt_movq_M0_wRn(int rn) -{ - iwmmxt_load_reg(cpu_M0, rn); -} - -static inline void gen_op_iwmmxt_orq_M0_wRn(int rn) -{ - iwmmxt_load_reg(cpu_V1, rn); - tcg_gen_or_i64(cpu_M0, cpu_M0, cpu_V1); -} - -static inline void gen_op_iwmmxt_andq_M0_wRn(int rn) -{ - iwmmxt_load_reg(cpu_V1, rn); - tcg_gen_and_i64(cpu_M0, cpu_M0, cpu_V1); -} - -static inline void gen_op_iwmmxt_xorq_M0_wRn(int rn) -{ - iwmmxt_load_reg(cpu_V1, rn); - tcg_gen_xor_i64(cpu_M0, cpu_M0, cpu_V1); -} - -#define IWMMXT_OP(name) \ -static inline void gen_op_iwmmxt_##name##_M0_wRn(int rn) \ -{ \ - iwmmxt_load_reg(cpu_V1, rn); \ - gen_helper_iwmmxt_##name(cpu_M0, cpu_M0, cpu_V1); \ -} - -#define IWMMXT_OP_ENV(name) \ -static inline void gen_op_iwmmxt_##name##_M0_wRn(int rn) \ -{ \ - iwmmxt_load_reg(cpu_V1, rn); \ - gen_helper_iwmmxt_##name(cpu_M0, cpu_env, cpu_M0, cpu_V1); \ -} - -#define IWMMXT_OP_ENV_SIZE(name) \ -IWMMXT_OP_ENV(name##b) \ -IWMMXT_OP_ENV(name##w) \ -IWMMXT_OP_ENV(name##l) - -#define IWMMXT_OP_ENV1(name) \ -static inline void gen_op_iwmmxt_##name##_M0(void) \ -{ \ - gen_helper_iwmmxt_##name(cpu_M0, cpu_env, cpu_M0); \ -} - -IWMMXT_OP(maddsq) -IWMMXT_OP(madduq) -IWMMXT_OP(sadb) -IWMMXT_OP(sadw) -IWMMXT_OP(mulslw) -IWMMXT_OP(mulshw) -IWMMXT_OP(mululw) -IWMMXT_OP(muluhw) -IWMMXT_OP(macsw) -IWMMXT_OP(macuw) - -IWMMXT_OP_ENV_SIZE(unpackl) -IWMMXT_OP_ENV_SIZE(unpackh) - -IWMMXT_OP_ENV1(unpacklub) -IWMMXT_OP_ENV1(unpackluw) -IWMMXT_OP_ENV1(unpacklul) -IWMMXT_OP_ENV1(unpackhub) -IWMMXT_OP_ENV1(unpackhuw) -IWMMXT_OP_ENV1(unpackhul) -IWMMXT_OP_ENV1(unpacklsb) -IWMMXT_OP_ENV1(unpacklsw) -IWMMXT_OP_ENV1(unpacklsl) -IWMMXT_OP_ENV1(unpackhsb) -IWMMXT_OP_ENV1(unpackhsw) -IWMMXT_OP_ENV1(unpackhsl) - -IWMMXT_OP_ENV_SIZE(cmpeq) -IWMMXT_OP_ENV_SIZE(cmpgtu) -IWMMXT_OP_ENV_SIZE(cmpgts) - -IWMMXT_OP_ENV_SIZE(mins) -IWMMXT_OP_ENV_SIZE(minu) -IWMMXT_OP_ENV_SIZE(maxs) -IWMMXT_OP_ENV_SIZE(maxu) - -IWMMXT_OP_ENV_SIZE(subn) -IWMMXT_OP_ENV_SIZE(addn) -IWMMXT_OP_ENV_SIZE(subu) -IWMMXT_OP_ENV_SIZE(addu) -IWMMXT_OP_ENV_SIZE(subs) -IWMMXT_OP_ENV_SIZE(adds) - -IWMMXT_OP_ENV(avgb0) -IWMMXT_OP_ENV(avgb1) -IWMMXT_OP_ENV(avgw0) -IWMMXT_OP_ENV(avgw1) - -IWMMXT_OP(msadb) - -IWMMXT_OP_ENV(packuw) -IWMMXT_OP_ENV(packul) -IWMMXT_OP_ENV(packuq) -IWMMXT_OP_ENV(packsw) -IWMMXT_OP_ENV(packsl) -IWMMXT_OP_ENV(packsq) - -static void gen_op_iwmmxt_set_mup(void) -{ - TCGv tmp; - tmp = load_cpu_field(iwmmxt.cregs[ARM_IWMMXT_wCon]); - tcg_gen_ori_i32(tmp, tmp, 2); - store_cpu_field(tmp, iwmmxt.cregs[ARM_IWMMXT_wCon]); -} - -static void gen_op_iwmmxt_set_cup(void) -{ - TCGv tmp; - tmp = load_cpu_field(iwmmxt.cregs[ARM_IWMMXT_wCon]); - tcg_gen_ori_i32(tmp, tmp, 1); - store_cpu_field(tmp, iwmmxt.cregs[ARM_IWMMXT_wCon]); -} - -static void gen_op_iwmmxt_setpsr_nz(void) -{ - TCGv tmp = new_tmp(); - gen_helper_iwmmxt_setpsr_nz(tmp, cpu_M0); - store_cpu_field(tmp, iwmmxt.cregs[ARM_IWMMXT_wCASF]); -} - -static inline void gen_op_iwmmxt_addl_M0_wRn(int rn) -{ - iwmmxt_load_reg(cpu_V1, rn); - tcg_gen_ext32u_i64(cpu_V1, cpu_V1); - tcg_gen_add_i64(cpu_M0, cpu_M0, cpu_V1); -} - -static inline int gen_iwmmxt_address(DisasContext *s, uint32_t insn, TCGv dest) -{ - int rd; - uint32_t offset; - TCGv tmp; - - rd = (insn >> 16) & 0xf; - tmp = load_reg(s, rd); - - offset = (insn & 0xff) << ((insn >> 7) & 2); - if (insn & (1 << 24)) { - /* Pre indexed */ - if (insn & (1 << 23)) - tcg_gen_addi_i32(tmp, tmp, offset); - else - tcg_gen_addi_i32(tmp, tmp, -offset); - tcg_gen_mov_i32(dest, tmp); - if (insn & (1 << 21)) - store_reg(s, rd, tmp); - else - dead_tmp(tmp); - } else if (insn & (1 << 21)) { - /* Post indexed */ - tcg_gen_mov_i32(dest, tmp); - if (insn & (1 << 23)) - tcg_gen_addi_i32(tmp, tmp, offset); - else - tcg_gen_addi_i32(tmp, tmp, -offset); - store_reg(s, rd, tmp); - } else if (!(insn & (1 << 23))) - return 1; - return 0; -} - -static inline int gen_iwmmxt_shift(uint32_t insn, uint32_t mask, TCGv dest) -{ - int rd = (insn >> 0) & 0xf; - TCGv tmp; - - if (insn & (1 << 8)) { - if (rd < ARM_IWMMXT_wCGR0 || rd > ARM_IWMMXT_wCGR3) { - return 1; - } else { - tmp = iwmmxt_load_creg(rd); - } - } else { - tmp = new_tmp(); - iwmmxt_load_reg(cpu_V0, rd); - tcg_gen_trunc_i64_i32(tmp, cpu_V0); - } - tcg_gen_andi_i32(tmp, tmp, mask); - tcg_gen_mov_i32(dest, tmp); - dead_tmp(tmp); - return 0; -} - -/* Disassemble an iwMMXt instruction. Returns nonzero if an error occured - (ie. an undefined instruction). */ -static int disas_iwmmxt_insn(CPUState *env, DisasContext *s, uint32_t insn) -{ - int rd, wrd; - int rdhi, rdlo, rd0, rd1, i; - TCGv addr; - TCGv tmp, tmp2, tmp3; - - if ((insn & 0x0e000e00) == 0x0c000000) { - if ((insn & 0x0fe00ff0) == 0x0c400000) { - wrd = insn & 0xf; - rdlo = (insn >> 12) & 0xf; - rdhi = (insn >> 16) & 0xf; - if (insn & ARM_CP_RW_BIT) { /* TMRRC */ - iwmmxt_load_reg(cpu_V0, wrd); - tcg_gen_trunc_i64_i32(cpu_R[rdlo], cpu_V0); - tcg_gen_shri_i64(cpu_V0, cpu_V0, 32); - tcg_gen_trunc_i64_i32(cpu_R[rdhi], cpu_V0); - } else { /* TMCRR */ - tcg_gen_concat_i32_i64(cpu_V0, cpu_R[rdlo], cpu_R[rdhi]); - iwmmxt_store_reg(cpu_V0, wrd); - gen_op_iwmmxt_set_mup(); - } - return 0; - } - - wrd = (insn >> 12) & 0xf; - addr = new_tmp(); - if (gen_iwmmxt_address(s, insn, addr)) { - dead_tmp(addr); - return 1; - } - if (insn & ARM_CP_RW_BIT) { - if ((insn >> 28) == 0xf) { /* WLDRW wCx */ - tmp = new_tmp(); - tcg_gen_qemu_ld32u(tmp, addr, IS_USER(s)); - iwmmxt_store_creg(wrd, tmp); - } else { - i = 1; - if (insn & (1 << 8)) { - if (insn & (1 << 22)) { /* WLDRD */ - tcg_gen_qemu_ld64(cpu_M0, addr, IS_USER(s)); - i = 0; - } else { /* WLDRW wRd */ - tmp = gen_ld32(addr, IS_USER(s)); - } - } else { - if (insn & (1 << 22)) { /* WLDRH */ - tmp = gen_ld16u(addr, IS_USER(s)); - } else { /* WLDRB */ - tmp = gen_ld8u(addr, IS_USER(s)); - } - } - if (i) { - tcg_gen_extu_i32_i64(cpu_M0, tmp); - dead_tmp(tmp); - } - gen_op_iwmmxt_movq_wRn_M0(wrd); - } - } else { - if ((insn >> 28) == 0xf) { /* WSTRW wCx */ - tmp = iwmmxt_load_creg(wrd); - gen_st32(tmp, addr, IS_USER(s)); - } else { - gen_op_iwmmxt_movq_M0_wRn(wrd); - tmp = new_tmp(); - if (insn & (1 << 8)) { - if (insn & (1 << 22)) { /* WSTRD */ - dead_tmp(tmp); - tcg_gen_qemu_st64(cpu_M0, addr, IS_USER(s)); - } else { /* WSTRW wRd */ - tcg_gen_trunc_i64_i32(tmp, cpu_M0); - gen_st32(tmp, addr, IS_USER(s)); - } - } else { - if (insn & (1 << 22)) { /* WSTRH */ - tcg_gen_trunc_i64_i32(tmp, cpu_M0); - gen_st16(tmp, addr, IS_USER(s)); - } else { /* WSTRB */ - tcg_gen_trunc_i64_i32(tmp, cpu_M0); - gen_st8(tmp, addr, IS_USER(s)); - } - } - } - } - return 0; - } - - if ((insn & 0x0f000000) != 0x0e000000) - return 1; - - switch (((insn >> 12) & 0xf00) | ((insn >> 4) & 0xff)) { - case 0x000: /* WOR */ - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 0) & 0xf; - rd1 = (insn >> 16) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - gen_op_iwmmxt_orq_M0_wRn(rd1); - gen_op_iwmmxt_setpsr_nz(); - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - gen_op_iwmmxt_set_cup(); - break; - case 0x011: /* TMCR */ - if (insn & 0xf) - return 1; - rd = (insn >> 12) & 0xf; - wrd = (insn >> 16) & 0xf; - switch (wrd) { - case ARM_IWMMXT_wCID: - case ARM_IWMMXT_wCASF: - break; - case ARM_IWMMXT_wCon: - gen_op_iwmmxt_set_cup(); - /* Fall through. */ - case ARM_IWMMXT_wCSSF: - tmp = iwmmxt_load_creg(wrd); - tmp2 = load_reg(s, rd); - tcg_gen_andc_i32(tmp, tmp, tmp2); - dead_tmp(tmp2); - iwmmxt_store_creg(wrd, tmp); - break; - case ARM_IWMMXT_wCGR0: - case ARM_IWMMXT_wCGR1: - case ARM_IWMMXT_wCGR2: - case ARM_IWMMXT_wCGR3: - gen_op_iwmmxt_set_cup(); - tmp = load_reg(s, rd); - iwmmxt_store_creg(wrd, tmp); - break; - default: - return 1; - } - break; - case 0x100: /* WXOR */ - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 0) & 0xf; - rd1 = (insn >> 16) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - gen_op_iwmmxt_xorq_M0_wRn(rd1); - gen_op_iwmmxt_setpsr_nz(); - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - gen_op_iwmmxt_set_cup(); - break; - case 0x111: /* TMRC */ - if (insn & 0xf) - return 1; - rd = (insn >> 12) & 0xf; - wrd = (insn >> 16) & 0xf; - tmp = iwmmxt_load_creg(wrd); - store_reg(s, rd, tmp); - break; - case 0x300: /* WANDN */ - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 0) & 0xf; - rd1 = (insn >> 16) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - tcg_gen_neg_i64(cpu_M0, cpu_M0); - gen_op_iwmmxt_andq_M0_wRn(rd1); - gen_op_iwmmxt_setpsr_nz(); - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - gen_op_iwmmxt_set_cup(); - break; - case 0x200: /* WAND */ - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 0) & 0xf; - rd1 = (insn >> 16) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - gen_op_iwmmxt_andq_M0_wRn(rd1); - gen_op_iwmmxt_setpsr_nz(); - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - gen_op_iwmmxt_set_cup(); - break; - case 0x810: case 0xa10: /* WMADD */ - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 0) & 0xf; - rd1 = (insn >> 16) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - if (insn & (1 << 21)) - gen_op_iwmmxt_maddsq_M0_wRn(rd1); - else - gen_op_iwmmxt_madduq_M0_wRn(rd1); - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - break; - case 0x10e: case 0x50e: case 0x90e: case 0xd0e: /* WUNPCKIL */ - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - rd1 = (insn >> 0) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - switch ((insn >> 22) & 3) { - case 0: - gen_op_iwmmxt_unpacklb_M0_wRn(rd1); - break; - case 1: - gen_op_iwmmxt_unpacklw_M0_wRn(rd1); - break; - case 2: - gen_op_iwmmxt_unpackll_M0_wRn(rd1); - break; - case 3: - return 1; - } - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - gen_op_iwmmxt_set_cup(); - break; - case 0x10c: case 0x50c: case 0x90c: case 0xd0c: /* WUNPCKIH */ - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - rd1 = (insn >> 0) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - switch ((insn >> 22) & 3) { - case 0: - gen_op_iwmmxt_unpackhb_M0_wRn(rd1); - break; - case 1: - gen_op_iwmmxt_unpackhw_M0_wRn(rd1); - break; - case 2: - gen_op_iwmmxt_unpackhl_M0_wRn(rd1); - break; - case 3: - return 1; - } - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - gen_op_iwmmxt_set_cup(); - break; - case 0x012: case 0x112: case 0x412: case 0x512: /* WSAD */ - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - rd1 = (insn >> 0) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - if (insn & (1 << 22)) - gen_op_iwmmxt_sadw_M0_wRn(rd1); - else - gen_op_iwmmxt_sadb_M0_wRn(rd1); - if (!(insn & (1 << 20))) - gen_op_iwmmxt_addl_M0_wRn(wrd); - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - break; - case 0x010: case 0x110: case 0x210: case 0x310: /* WMUL */ - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - rd1 = (insn >> 0) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - if (insn & (1 << 21)) { - if (insn & (1 << 20)) - gen_op_iwmmxt_mulshw_M0_wRn(rd1); - else - gen_op_iwmmxt_mulslw_M0_wRn(rd1); - } else { - if (insn & (1 << 20)) - gen_op_iwmmxt_muluhw_M0_wRn(rd1); - else - gen_op_iwmmxt_mululw_M0_wRn(rd1); - } - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - break; - case 0x410: case 0x510: case 0x610: case 0x710: /* WMAC */ - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - rd1 = (insn >> 0) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - if (insn & (1 << 21)) - gen_op_iwmmxt_macsw_M0_wRn(rd1); - else - gen_op_iwmmxt_macuw_M0_wRn(rd1); - if (!(insn & (1 << 20))) { - iwmmxt_load_reg(cpu_V1, wrd); - tcg_gen_add_i64(cpu_M0, cpu_M0, cpu_V1); - } - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - break; - case 0x006: case 0x406: case 0x806: case 0xc06: /* WCMPEQ */ - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - rd1 = (insn >> 0) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - switch ((insn >> 22) & 3) { - case 0: - gen_op_iwmmxt_cmpeqb_M0_wRn(rd1); - break; - case 1: - gen_op_iwmmxt_cmpeqw_M0_wRn(rd1); - break; - case 2: - gen_op_iwmmxt_cmpeql_M0_wRn(rd1); - break; - case 3: - return 1; - } - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - gen_op_iwmmxt_set_cup(); - break; - case 0x800: case 0x900: case 0xc00: case 0xd00: /* WAVG2 */ - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - rd1 = (insn >> 0) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - if (insn & (1 << 22)) { - if (insn & (1 << 20)) - gen_op_iwmmxt_avgw1_M0_wRn(rd1); - else - gen_op_iwmmxt_avgw0_M0_wRn(rd1); - } else { - if (insn & (1 << 20)) - gen_op_iwmmxt_avgb1_M0_wRn(rd1); - else - gen_op_iwmmxt_avgb0_M0_wRn(rd1); - } - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - gen_op_iwmmxt_set_cup(); - break; - case 0x802: case 0x902: case 0xa02: case 0xb02: /* WALIGNR */ - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - rd1 = (insn >> 0) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - tmp = iwmmxt_load_creg(ARM_IWMMXT_wCGR0 + ((insn >> 20) & 3)); - tcg_gen_andi_i32(tmp, tmp, 7); - iwmmxt_load_reg(cpu_V1, rd1); - gen_helper_iwmmxt_align(cpu_M0, cpu_M0, cpu_V1, tmp); - dead_tmp(tmp); - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - break; - case 0x601: case 0x605: case 0x609: case 0x60d: /* TINSR */ - if (((insn >> 6) & 3) == 3) - return 1; - rd = (insn >> 12) & 0xf; - wrd = (insn >> 16) & 0xf; - tmp = load_reg(s, rd); - gen_op_iwmmxt_movq_M0_wRn(wrd); - switch ((insn >> 6) & 3) { - case 0: - tmp2 = tcg_const_i32(0xff); - tmp3 = tcg_const_i32((insn & 7) << 3); - break; - case 1: - tmp2 = tcg_const_i32(0xffff); - tmp3 = tcg_const_i32((insn & 3) << 4); - break; - case 2: - tmp2 = tcg_const_i32(0xffffffff); - tmp3 = tcg_const_i32((insn & 1) << 5); - break; - default: - TCGV_UNUSED(tmp2); - TCGV_UNUSED(tmp3); - } - gen_helper_iwmmxt_insr(cpu_M0, cpu_M0, tmp, tmp2, tmp3); - tcg_temp_free(tmp3); - tcg_temp_free(tmp2); - dead_tmp(tmp); - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - break; - case 0x107: case 0x507: case 0x907: case 0xd07: /* TEXTRM */ - rd = (insn >> 12) & 0xf; - wrd = (insn >> 16) & 0xf; - if (rd == 15 || ((insn >> 22) & 3) == 3) - return 1; - gen_op_iwmmxt_movq_M0_wRn(wrd); - tmp = new_tmp(); - switch ((insn >> 22) & 3) { - case 0: - tcg_gen_shri_i64(cpu_M0, cpu_M0, (insn & 7) << 3); - tcg_gen_trunc_i64_i32(tmp, cpu_M0); - if (insn & 8) { - tcg_gen_ext8s_i32(tmp, tmp); - } else { - tcg_gen_andi_i32(tmp, tmp, 0xff); - } - break; - case 1: - tcg_gen_shri_i64(cpu_M0, cpu_M0, (insn & 3) << 4); - tcg_gen_trunc_i64_i32(tmp, cpu_M0); - if (insn & 8) { - tcg_gen_ext16s_i32(tmp, tmp); - } else { - tcg_gen_andi_i32(tmp, tmp, 0xffff); - } - break; - case 2: - tcg_gen_shri_i64(cpu_M0, cpu_M0, (insn & 1) << 5); - tcg_gen_trunc_i64_i32(tmp, cpu_M0); - break; - } - store_reg(s, rd, tmp); - break; - case 0x117: case 0x517: case 0x917: case 0xd17: /* TEXTRC */ - if ((insn & 0x000ff008) != 0x0003f000 || ((insn >> 22) & 3) == 3) - return 1; - tmp = iwmmxt_load_creg(ARM_IWMMXT_wCASF); - switch ((insn >> 22) & 3) { - case 0: - tcg_gen_shri_i32(tmp, tmp, ((insn & 7) << 2) + 0); - break; - case 1: - tcg_gen_shri_i32(tmp, tmp, ((insn & 3) << 3) + 4); - break; - case 2: - tcg_gen_shri_i32(tmp, tmp, ((insn & 1) << 4) + 12); - break; - } - tcg_gen_shli_i32(tmp, tmp, 28); - gen_set_nzcv(tmp); - dead_tmp(tmp); - break; - case 0x401: case 0x405: case 0x409: case 0x40d: /* TBCST */ - if (((insn >> 6) & 3) == 3) - return 1; - rd = (insn >> 12) & 0xf; - wrd = (insn >> 16) & 0xf; - tmp = load_reg(s, rd); - switch ((insn >> 6) & 3) { - case 0: - gen_helper_iwmmxt_bcstb(cpu_M0, tmp); - break; - case 1: - gen_helper_iwmmxt_bcstw(cpu_M0, tmp); - break; - case 2: - gen_helper_iwmmxt_bcstl(cpu_M0, tmp); - break; - } - dead_tmp(tmp); - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - break; - case 0x113: case 0x513: case 0x913: case 0xd13: /* TANDC */ - if ((insn & 0x000ff00f) != 0x0003f000 || ((insn >> 22) & 3) == 3) - return 1; - tmp = iwmmxt_load_creg(ARM_IWMMXT_wCASF); - tmp2 = new_tmp(); - tcg_gen_mov_i32(tmp2, tmp); - switch ((insn >> 22) & 3) { - case 0: - for (i = 0; i < 7; i ++) { - tcg_gen_shli_i32(tmp2, tmp2, 4); - tcg_gen_and_i32(tmp, tmp, tmp2); - } - break; - case 1: - for (i = 0; i < 3; i ++) { - tcg_gen_shli_i32(tmp2, tmp2, 8); - tcg_gen_and_i32(tmp, tmp, tmp2); - } - break; - case 2: - tcg_gen_shli_i32(tmp2, tmp2, 16); - tcg_gen_and_i32(tmp, tmp, tmp2); - break; - } - gen_set_nzcv(tmp); - dead_tmp(tmp2); - dead_tmp(tmp); - break; - case 0x01c: case 0x41c: case 0x81c: case 0xc1c: /* WACC */ - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - switch ((insn >> 22) & 3) { - case 0: - gen_helper_iwmmxt_addcb(cpu_M0, cpu_M0); - break; - case 1: - gen_helper_iwmmxt_addcw(cpu_M0, cpu_M0); - break; - case 2: - gen_helper_iwmmxt_addcl(cpu_M0, cpu_M0); - break; - case 3: - return 1; - } - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - break; - case 0x115: case 0x515: case 0x915: case 0xd15: /* TORC */ - if ((insn & 0x000ff00f) != 0x0003f000 || ((insn >> 22) & 3) == 3) - return 1; - tmp = iwmmxt_load_creg(ARM_IWMMXT_wCASF); - tmp2 = new_tmp(); - tcg_gen_mov_i32(tmp2, tmp); - switch ((insn >> 22) & 3) { - case 0: - for (i = 0; i < 7; i ++) { - tcg_gen_shli_i32(tmp2, tmp2, 4); - tcg_gen_or_i32(tmp, tmp, tmp2); - } - break; - case 1: - for (i = 0; i < 3; i ++) { - tcg_gen_shli_i32(tmp2, tmp2, 8); - tcg_gen_or_i32(tmp, tmp, tmp2); - } - break; - case 2: - tcg_gen_shli_i32(tmp2, tmp2, 16); - tcg_gen_or_i32(tmp, tmp, tmp2); - break; - } - gen_set_nzcv(tmp); - dead_tmp(tmp2); - dead_tmp(tmp); - break; - case 0x103: case 0x503: case 0x903: case 0xd03: /* TMOVMSK */ - rd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - if ((insn & 0xf) != 0 || ((insn >> 22) & 3) == 3) - return 1; - gen_op_iwmmxt_movq_M0_wRn(rd0); - tmp = new_tmp(); - switch ((insn >> 22) & 3) { - case 0: - gen_helper_iwmmxt_msbb(tmp, cpu_M0); - break; - case 1: - gen_helper_iwmmxt_msbw(tmp, cpu_M0); - break; - case 2: - gen_helper_iwmmxt_msbl(tmp, cpu_M0); - break; - } - store_reg(s, rd, tmp); - break; - case 0x106: case 0x306: case 0x506: case 0x706: /* WCMPGT */ - case 0x906: case 0xb06: case 0xd06: case 0xf06: - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - rd1 = (insn >> 0) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - switch ((insn >> 22) & 3) { - case 0: - if (insn & (1 << 21)) - gen_op_iwmmxt_cmpgtsb_M0_wRn(rd1); - else - gen_op_iwmmxt_cmpgtub_M0_wRn(rd1); - break; - case 1: - if (insn & (1 << 21)) - gen_op_iwmmxt_cmpgtsw_M0_wRn(rd1); - else - gen_op_iwmmxt_cmpgtuw_M0_wRn(rd1); - break; - case 2: - if (insn & (1 << 21)) - gen_op_iwmmxt_cmpgtsl_M0_wRn(rd1); - else - gen_op_iwmmxt_cmpgtul_M0_wRn(rd1); - break; - case 3: - return 1; - } - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - gen_op_iwmmxt_set_cup(); - break; - case 0x00e: case 0x20e: case 0x40e: case 0x60e: /* WUNPCKEL */ - case 0x80e: case 0xa0e: case 0xc0e: case 0xe0e: - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - switch ((insn >> 22) & 3) { - case 0: - if (insn & (1 << 21)) - gen_op_iwmmxt_unpacklsb_M0(); - else - gen_op_iwmmxt_unpacklub_M0(); - break; - case 1: - if (insn & (1 << 21)) - gen_op_iwmmxt_unpacklsw_M0(); - else - gen_op_iwmmxt_unpackluw_M0(); - break; - case 2: - if (insn & (1 << 21)) - gen_op_iwmmxt_unpacklsl_M0(); - else - gen_op_iwmmxt_unpacklul_M0(); - break; - case 3: - return 1; - } - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - gen_op_iwmmxt_set_cup(); - break; - case 0x00c: case 0x20c: case 0x40c: case 0x60c: /* WUNPCKEH */ - case 0x80c: case 0xa0c: case 0xc0c: case 0xe0c: - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - switch ((insn >> 22) & 3) { - case 0: - if (insn & (1 << 21)) - gen_op_iwmmxt_unpackhsb_M0(); - else - gen_op_iwmmxt_unpackhub_M0(); - break; - case 1: - if (insn & (1 << 21)) - gen_op_iwmmxt_unpackhsw_M0(); - else - gen_op_iwmmxt_unpackhuw_M0(); - break; - case 2: - if (insn & (1 << 21)) - gen_op_iwmmxt_unpackhsl_M0(); - else - gen_op_iwmmxt_unpackhul_M0(); - break; - case 3: - return 1; - } - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - gen_op_iwmmxt_set_cup(); - break; - case 0x204: case 0x604: case 0xa04: case 0xe04: /* WSRL */ - case 0x214: case 0x614: case 0xa14: case 0xe14: - if (((insn >> 22) & 3) == 0) - return 1; - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - tmp = new_tmp(); - if (gen_iwmmxt_shift(insn, 0xff, tmp)) { - dead_tmp(tmp); - return 1; - } - switch ((insn >> 22) & 3) { - case 1: - gen_helper_iwmmxt_srlw(cpu_M0, cpu_env, cpu_M0, tmp); - break; - case 2: - gen_helper_iwmmxt_srll(cpu_M0, cpu_env, cpu_M0, tmp); - break; - case 3: - gen_helper_iwmmxt_srlq(cpu_M0, cpu_env, cpu_M0, tmp); - break; - } - dead_tmp(tmp); - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - gen_op_iwmmxt_set_cup(); - break; - case 0x004: case 0x404: case 0x804: case 0xc04: /* WSRA */ - case 0x014: case 0x414: case 0x814: case 0xc14: - if (((insn >> 22) & 3) == 0) - return 1; - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - tmp = new_tmp(); - if (gen_iwmmxt_shift(insn, 0xff, tmp)) { - dead_tmp(tmp); - return 1; - } - switch ((insn >> 22) & 3) { - case 1: - gen_helper_iwmmxt_sraw(cpu_M0, cpu_env, cpu_M0, tmp); - break; - case 2: - gen_helper_iwmmxt_sral(cpu_M0, cpu_env, cpu_M0, tmp); - break; - case 3: - gen_helper_iwmmxt_sraq(cpu_M0, cpu_env, cpu_M0, tmp); - break; - } - dead_tmp(tmp); - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - gen_op_iwmmxt_set_cup(); - break; - case 0x104: case 0x504: case 0x904: case 0xd04: /* WSLL */ - case 0x114: case 0x514: case 0x914: case 0xd14: - if (((insn >> 22) & 3) == 0) - return 1; - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - tmp = new_tmp(); - if (gen_iwmmxt_shift(insn, 0xff, tmp)) { - dead_tmp(tmp); - return 1; - } - switch ((insn >> 22) & 3) { - case 1: - gen_helper_iwmmxt_sllw(cpu_M0, cpu_env, cpu_M0, tmp); - break; - case 2: - gen_helper_iwmmxt_slll(cpu_M0, cpu_env, cpu_M0, tmp); - break; - case 3: - gen_helper_iwmmxt_sllq(cpu_M0, cpu_env, cpu_M0, tmp); - break; - } - dead_tmp(tmp); - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - gen_op_iwmmxt_set_cup(); - break; - case 0x304: case 0x704: case 0xb04: case 0xf04: /* WROR */ - case 0x314: case 0x714: case 0xb14: case 0xf14: - if (((insn >> 22) & 3) == 0) - return 1; - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - tmp = new_tmp(); - switch ((insn >> 22) & 3) { - case 1: - if (gen_iwmmxt_shift(insn, 0xf, tmp)) { - dead_tmp(tmp); - return 1; - } - gen_helper_iwmmxt_rorw(cpu_M0, cpu_env, cpu_M0, tmp); - break; - case 2: - if (gen_iwmmxt_shift(insn, 0x1f, tmp)) { - dead_tmp(tmp); - return 1; - } - gen_helper_iwmmxt_rorl(cpu_M0, cpu_env, cpu_M0, tmp); - break; - case 3: - if (gen_iwmmxt_shift(insn, 0x3f, tmp)) { - dead_tmp(tmp); - return 1; - } - gen_helper_iwmmxt_rorq(cpu_M0, cpu_env, cpu_M0, tmp); - break; - } - dead_tmp(tmp); - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - gen_op_iwmmxt_set_cup(); - break; - case 0x116: case 0x316: case 0x516: case 0x716: /* WMIN */ - case 0x916: case 0xb16: case 0xd16: case 0xf16: - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - rd1 = (insn >> 0) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - switch ((insn >> 22) & 3) { - case 0: - if (insn & (1 << 21)) - gen_op_iwmmxt_minsb_M0_wRn(rd1); - else - gen_op_iwmmxt_minub_M0_wRn(rd1); - break; - case 1: - if (insn & (1 << 21)) - gen_op_iwmmxt_minsw_M0_wRn(rd1); - else - gen_op_iwmmxt_minuw_M0_wRn(rd1); - break; - case 2: - if (insn & (1 << 21)) - gen_op_iwmmxt_minsl_M0_wRn(rd1); - else - gen_op_iwmmxt_minul_M0_wRn(rd1); - break; - case 3: - return 1; - } - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - break; - case 0x016: case 0x216: case 0x416: case 0x616: /* WMAX */ - case 0x816: case 0xa16: case 0xc16: case 0xe16: - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - rd1 = (insn >> 0) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - switch ((insn >> 22) & 3) { - case 0: - if (insn & (1 << 21)) - gen_op_iwmmxt_maxsb_M0_wRn(rd1); - else - gen_op_iwmmxt_maxub_M0_wRn(rd1); - break; - case 1: - if (insn & (1 << 21)) - gen_op_iwmmxt_maxsw_M0_wRn(rd1); - else - gen_op_iwmmxt_maxuw_M0_wRn(rd1); - break; - case 2: - if (insn & (1 << 21)) - gen_op_iwmmxt_maxsl_M0_wRn(rd1); - else - gen_op_iwmmxt_maxul_M0_wRn(rd1); - break; - case 3: - return 1; - } - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - break; - case 0x002: case 0x102: case 0x202: case 0x302: /* WALIGNI */ - case 0x402: case 0x502: case 0x602: case 0x702: - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - rd1 = (insn >> 0) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - tmp = tcg_const_i32((insn >> 20) & 3); - iwmmxt_load_reg(cpu_V1, rd1); - gen_helper_iwmmxt_align(cpu_M0, cpu_M0, cpu_V1, tmp); - tcg_temp_free(tmp); - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - break; - case 0x01a: case 0x11a: case 0x21a: case 0x31a: /* WSUB */ - case 0x41a: case 0x51a: case 0x61a: case 0x71a: - case 0x81a: case 0x91a: case 0xa1a: case 0xb1a: - case 0xc1a: case 0xd1a: case 0xe1a: case 0xf1a: - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - rd1 = (insn >> 0) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - switch ((insn >> 20) & 0xf) { - case 0x0: - gen_op_iwmmxt_subnb_M0_wRn(rd1); - break; - case 0x1: - gen_op_iwmmxt_subub_M0_wRn(rd1); - break; - case 0x3: - gen_op_iwmmxt_subsb_M0_wRn(rd1); - break; - case 0x4: - gen_op_iwmmxt_subnw_M0_wRn(rd1); - break; - case 0x5: - gen_op_iwmmxt_subuw_M0_wRn(rd1); - break; - case 0x7: - gen_op_iwmmxt_subsw_M0_wRn(rd1); - break; - case 0x8: - gen_op_iwmmxt_subnl_M0_wRn(rd1); - break; - case 0x9: - gen_op_iwmmxt_subul_M0_wRn(rd1); - break; - case 0xb: - gen_op_iwmmxt_subsl_M0_wRn(rd1); - break; - default: - return 1; - } - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - gen_op_iwmmxt_set_cup(); - break; - case 0x01e: case 0x11e: case 0x21e: case 0x31e: /* WSHUFH */ - case 0x41e: case 0x51e: case 0x61e: case 0x71e: - case 0x81e: case 0x91e: case 0xa1e: case 0xb1e: - case 0xc1e: case 0xd1e: case 0xe1e: case 0xf1e: - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - tmp = tcg_const_i32(((insn >> 16) & 0xf0) | (insn & 0x0f)); - gen_helper_iwmmxt_shufh(cpu_M0, cpu_env, cpu_M0, tmp); - tcg_temp_free(tmp); - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - gen_op_iwmmxt_set_cup(); - break; - case 0x018: case 0x118: case 0x218: case 0x318: /* WADD */ - case 0x418: case 0x518: case 0x618: case 0x718: - case 0x818: case 0x918: case 0xa18: case 0xb18: - case 0xc18: case 0xd18: case 0xe18: case 0xf18: - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - rd1 = (insn >> 0) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - switch ((insn >> 20) & 0xf) { - case 0x0: - gen_op_iwmmxt_addnb_M0_wRn(rd1); - break; - case 0x1: - gen_op_iwmmxt_addub_M0_wRn(rd1); - break; - case 0x3: - gen_op_iwmmxt_addsb_M0_wRn(rd1); - break; - case 0x4: - gen_op_iwmmxt_addnw_M0_wRn(rd1); - break; - case 0x5: - gen_op_iwmmxt_adduw_M0_wRn(rd1); - break; - case 0x7: - gen_op_iwmmxt_addsw_M0_wRn(rd1); - break; - case 0x8: - gen_op_iwmmxt_addnl_M0_wRn(rd1); - break; - case 0x9: - gen_op_iwmmxt_addul_M0_wRn(rd1); - break; - case 0xb: - gen_op_iwmmxt_addsl_M0_wRn(rd1); - break; - default: - return 1; - } - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - gen_op_iwmmxt_set_cup(); - break; - case 0x008: case 0x108: case 0x208: case 0x308: /* WPACK */ - case 0x408: case 0x508: case 0x608: case 0x708: - case 0x808: case 0x908: case 0xa08: case 0xb08: - case 0xc08: case 0xd08: case 0xe08: case 0xf08: - if (!(insn & (1 << 20)) || ((insn >> 22) & 3) == 0) - return 1; - wrd = (insn >> 12) & 0xf; - rd0 = (insn >> 16) & 0xf; - rd1 = (insn >> 0) & 0xf; - gen_op_iwmmxt_movq_M0_wRn(rd0); - switch ((insn >> 22) & 3) { - case 1: - if (insn & (1 << 21)) - gen_op_iwmmxt_packsw_M0_wRn(rd1); - else - gen_op_iwmmxt_packuw_M0_wRn(rd1); - break; - case 2: - if (insn & (1 << 21)) - gen_op_iwmmxt_packsl_M0_wRn(rd1); - else - gen_op_iwmmxt_packul_M0_wRn(rd1); - break; - case 3: - if (insn & (1 << 21)) - gen_op_iwmmxt_packsq_M0_wRn(rd1); - else - gen_op_iwmmxt_packuq_M0_wRn(rd1); - break; - } - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - gen_op_iwmmxt_set_cup(); - break; - case 0x201: case 0x203: case 0x205: case 0x207: - case 0x209: case 0x20b: case 0x20d: case 0x20f: - case 0x211: case 0x213: case 0x215: case 0x217: - case 0x219: case 0x21b: case 0x21d: case 0x21f: - wrd = (insn >> 5) & 0xf; - rd0 = (insn >> 12) & 0xf; - rd1 = (insn >> 0) & 0xf; - if (rd0 == 0xf || rd1 == 0xf) - return 1; - gen_op_iwmmxt_movq_M0_wRn(wrd); - tmp = load_reg(s, rd0); - tmp2 = load_reg(s, rd1); - switch ((insn >> 16) & 0xf) { - case 0x0: /* TMIA */ - gen_helper_iwmmxt_muladdsl(cpu_M0, cpu_M0, tmp, tmp2); - break; - case 0x8: /* TMIAPH */ - gen_helper_iwmmxt_muladdsw(cpu_M0, cpu_M0, tmp, tmp2); - break; - case 0xc: case 0xd: case 0xe: case 0xf: /* TMIAxy */ - if (insn & (1 << 16)) - tcg_gen_shri_i32(tmp, tmp, 16); - if (insn & (1 << 17)) - tcg_gen_shri_i32(tmp2, tmp2, 16); - gen_helper_iwmmxt_muladdswl(cpu_M0, cpu_M0, tmp, tmp2); - break; - default: - dead_tmp(tmp2); - dead_tmp(tmp); - return 1; - } - dead_tmp(tmp2); - dead_tmp(tmp); - gen_op_iwmmxt_movq_wRn_M0(wrd); - gen_op_iwmmxt_set_mup(); - break; - default: - return 1; - } - - return 0; -} - -/* Disassemble an XScale DSP instruction. Returns nonzero if an error occured - (ie. an undefined instruction). */ -static int disas_dsp_insn(CPUState *env, DisasContext *s, uint32_t insn) -{ - int acc, rd0, rd1, rdhi, rdlo; - TCGv tmp, tmp2; - - if ((insn & 0x0ff00f10) == 0x0e200010) { - /* Multiply with Internal Accumulate Format */ - rd0 = (insn >> 12) & 0xf; - rd1 = insn & 0xf; - acc = (insn >> 5) & 7; - - if (acc != 0) - return 1; - - tmp = load_reg(s, rd0); - tmp2 = load_reg(s, rd1); - switch ((insn >> 16) & 0xf) { - case 0x0: /* MIA */ - gen_helper_iwmmxt_muladdsl(cpu_M0, cpu_M0, tmp, tmp2); - break; - case 0x8: /* MIAPH */ - gen_helper_iwmmxt_muladdsw(cpu_M0, cpu_M0, tmp, tmp2); - break; - case 0xc: /* MIABB */ - case 0xd: /* MIABT */ - case 0xe: /* MIATB */ - case 0xf: /* MIATT */ - if (insn & (1 << 16)) - tcg_gen_shri_i32(tmp, tmp, 16); - if (insn & (1 << 17)) - tcg_gen_shri_i32(tmp2, tmp2, 16); - gen_helper_iwmmxt_muladdswl(cpu_M0, cpu_M0, tmp, tmp2); - break; - default: - return 1; - } - dead_tmp(tmp2); - dead_tmp(tmp); - - gen_op_iwmmxt_movq_wRn_M0(acc); - return 0; - } - - if ((insn & 0x0fe00ff8) == 0x0c400000) { - /* Internal Accumulator Access Format */ - rdhi = (insn >> 16) & 0xf; - rdlo = (insn >> 12) & 0xf; - acc = insn & 7; - - if (acc != 0) - return 1; - - if (insn & ARM_CP_RW_BIT) { /* MRA */ - iwmmxt_load_reg(cpu_V0, acc); - tcg_gen_trunc_i64_i32(cpu_R[rdlo], cpu_V0); - tcg_gen_shri_i64(cpu_V0, cpu_V0, 32); - tcg_gen_trunc_i64_i32(cpu_R[rdhi], cpu_V0); - tcg_gen_andi_i32(cpu_R[rdhi], cpu_R[rdhi], (1 << (40 - 32)) - 1); - } else { /* MAR */ - tcg_gen_concat_i32_i64(cpu_V0, cpu_R[rdlo], cpu_R[rdhi]); - iwmmxt_store_reg(cpu_V0, acc); - } - return 0; - } - - return 1; -} - -/* Disassemble system coprocessor instruction. Return nonzero if - instruction is not defined. */ -static int disas_cp_insn(CPUState *env, DisasContext *s, uint32_t insn) -{ - TCGv tmp, tmp2; - uint32_t rd = (insn >> 12) & 0xf; - uint32_t cp = (insn >> 8) & 0xf; - if (IS_USER(s)) { - return 1; - } - - if (insn & ARM_CP_RW_BIT) { - if (!env->cp[cp].cp_read) - return 1; - gen_set_pc_im(s->pc); - tmp = new_tmp(); - tmp2 = tcg_const_i32(insn); - gen_helper_get_cp(tmp, cpu_env, tmp2); - tcg_temp_free(tmp2); - store_reg(s, rd, tmp); - } else { - if (!env->cp[cp].cp_write) - return 1; - gen_set_pc_im(s->pc); - tmp = load_reg(s, rd); - tmp2 = tcg_const_i32(insn); - gen_helper_set_cp(cpu_env, tmp2, tmp); - tcg_temp_free(tmp2); - dead_tmp(tmp); - } - return 0; -} - -static int cp15_user_ok(uint32_t insn) -{ - int cpn = (insn >> 16) & 0xf; - int cpm = insn & 0xf; - int op = ((insn >> 5) & 7) | ((insn >> 18) & 0x38); - - if (cpn == 13 && cpm == 0) { - /* TLS register. */ - if (op == 2 || (op == 3 && (insn & ARM_CP_RW_BIT))) - return 1; - } - if (cpn == 7) { - /* ISB, DSB, DMB. */ - if ((cpm == 5 && op == 4) - || (cpm == 10 && (op == 4 || op == 5))) - return 1; - } - return 0; -} - -/* Disassemble system coprocessor (cp15) instruction. Return nonzero if - instruction is not defined. */ -static int disas_cp15_insn(CPUState *env, DisasContext *s, uint32_t insn) -{ - uint32_t rd; - TCGv tmp, tmp2; - - /* M profile cores use memory mapped registers instead of cp15. */ - if (arm_feature(env, ARM_FEATURE_M)) - return 1; - - if ((insn & (1 << 25)) == 0) { - if (insn & (1 << 20)) { - /* mrrc */ - return 1; - } - /* mcrr. Used for block cache operations, so implement as no-op. */ - return 0; - } - if ((insn & (1 << 4)) == 0) { - /* cdp */ - return 1; - } - if (IS_USER(s) && !cp15_user_ok(insn)) { - return 1; - } - if ((insn & 0x0fff0fff) == 0x0e070f90 - || (insn & 0x0fff0fff) == 0x0e070f58) { - /* Wait for interrupt. */ - gen_set_pc_im(s->pc); - s->is_jmp = DISAS_WFI; - return 0; - } - rd = (insn >> 12) & 0xf; - tmp2 = tcg_const_i32(insn); - if (insn & ARM_CP_RW_BIT) { - tmp = new_tmp(); - gen_helper_get_cp15(tmp, cpu_env, tmp2); - /* If the destination register is r15 then sets condition codes. */ - if (rd != 15) - store_reg(s, rd, tmp); - else - dead_tmp(tmp); - } else { - tmp = load_reg(s, rd); - gen_helper_set_cp15(cpu_env, tmp2, tmp); - dead_tmp(tmp); - /* Normally we would always end the TB here, but Linux - * arch/arm/mach-pxa/sleep.S expects two instructions following - * an MMU enable to execute from cache. Imitate this behaviour. */ - if (!arm_feature(env, ARM_FEATURE_XSCALE) || - (insn & 0x0fff0fff) != 0x0e010f10) - gen_lookup_tb(s); - } - tcg_temp_free_i32(tmp2); - return 0; -} - -#define VFP_REG_SHR(x, n) (((n) > 0) ? (x) >> (n) : (x) << -(n)) -#define VFP_SREG(insn, bigbit, smallbit) \ - ((VFP_REG_SHR(insn, bigbit - 1) & 0x1e) | (((insn) >> (smallbit)) & 1)) -#define VFP_DREG(reg, insn, bigbit, smallbit) do { \ - if (arm_feature(env, ARM_FEATURE_VFP3)) { \ - reg = (((insn) >> (bigbit)) & 0x0f) \ - | (((insn) >> ((smallbit) - 4)) & 0x10); \ - } else { \ - if (insn & (1 << (smallbit))) \ - return 1; \ - reg = ((insn) >> (bigbit)) & 0x0f; \ - }} while (0) - -#define VFP_SREG_D(insn) VFP_SREG(insn, 12, 22) -#define VFP_DREG_D(reg, insn) VFP_DREG(reg, insn, 12, 22) -#define VFP_SREG_N(insn) VFP_SREG(insn, 16, 7) -#define VFP_DREG_N(reg, insn) VFP_DREG(reg, insn, 16, 7) -#define VFP_SREG_M(insn) VFP_SREG(insn, 0, 5) -#define VFP_DREG_M(reg, insn) VFP_DREG(reg, insn, 0, 5) - -/* Move between integer and VFP cores. */ -static TCGv gen_vfp_mrs(void) -{ - TCGv tmp = new_tmp(); - tcg_gen_mov_i32(tmp, cpu_F0s); - return tmp; -} - -static void gen_vfp_msr(TCGv tmp) -{ - tcg_gen_mov_i32(cpu_F0s, tmp); - dead_tmp(tmp); -} - -static inline int -vfp_enabled(CPUState * env) -{ - return ((env->vfp.xregs[ARM_VFP_FPEXC] & (1 << 30)) != 0); -} - -static void gen_neon_dup_u8(TCGv var, int shift) -{ - TCGv tmp = new_tmp(); - if (shift) - tcg_gen_shri_i32(var, var, shift); - tcg_gen_ext8u_i32(var, var); - tcg_gen_shli_i32(tmp, var, 8); - tcg_gen_or_i32(var, var, tmp); - tcg_gen_shli_i32(tmp, var, 16); - tcg_gen_or_i32(var, var, tmp); - dead_tmp(tmp); -} - -static void gen_neon_dup_low16(TCGv var) -{ - TCGv tmp = new_tmp(); - tcg_gen_ext16u_i32(var, var); - tcg_gen_shli_i32(tmp, var, 16); - tcg_gen_or_i32(var, var, tmp); - dead_tmp(tmp); -} - -static void gen_neon_dup_high16(TCGv var) -{ - TCGv tmp = new_tmp(); - tcg_gen_andi_i32(var, var, 0xffff0000); - tcg_gen_shri_i32(tmp, var, 16); - tcg_gen_or_i32(var, var, tmp); - dead_tmp(tmp); -} - -/* Disassemble a VFP instruction. Returns nonzero if an error occured - (ie. an undefined instruction). */ -static int disas_vfp_insn(CPUState * env, DisasContext *s, uint32_t insn) -{ - uint32_t rd, rn, rm, op, i, n, offset, delta_d, delta_m, bank_mask; - int dp, veclen; - TCGv addr; - TCGv tmp; - TCGv tmp2; - - if (!arm_feature(env, ARM_FEATURE_VFP)) - return 1; - - if (!vfp_enabled(env)) { - /* VFP disabled. Only allow fmxr/fmrx to/from some control regs. */ - if ((insn & 0x0fe00fff) != 0x0ee00a10) - return 1; - rn = (insn >> 16) & 0xf; - if (rn != ARM_VFP_FPSID && rn != ARM_VFP_FPEXC - && rn != ARM_VFP_MVFR1 && rn != ARM_VFP_MVFR0) - return 1; - } - dp = ((insn & 0xf00) == 0xb00); - switch ((insn >> 24) & 0xf) { - case 0xe: - if (insn & (1 << 4)) { - /* single register transfer */ - rd = (insn >> 12) & 0xf; - if (dp) { - int size; - int pass; - - VFP_DREG_N(rn, insn); - if (insn & 0xf) - return 1; - if (insn & 0x00c00060 - && !arm_feature(env, ARM_FEATURE_NEON)) - return 1; - - pass = (insn >> 21) & 1; - if (insn & (1 << 22)) { - size = 0; - offset = ((insn >> 5) & 3) * 8; - } else if (insn & (1 << 5)) { - size = 1; - offset = (insn & (1 << 6)) ? 16 : 0; - } else { - size = 2; - offset = 0; - } - if (insn & ARM_CP_RW_BIT) { - /* vfp->arm */ - tmp = neon_load_reg(rn, pass); - switch (size) { - case 0: - if (offset) - tcg_gen_shri_i32(tmp, tmp, offset); - if (insn & (1 << 23)) - gen_uxtb(tmp); - else - gen_sxtb(tmp); - break; - case 1: - if (insn & (1 << 23)) { - if (offset) { - tcg_gen_shri_i32(tmp, tmp, 16); - } else { - gen_uxth(tmp); - } - } else { - if (offset) { - tcg_gen_sari_i32(tmp, tmp, 16); - } else { - gen_sxth(tmp); - } - } - break; - case 2: - break; - } - store_reg(s, rd, tmp); - } else { - /* arm->vfp */ - tmp = load_reg(s, rd); - if (insn & (1 << 23)) { - /* VDUP */ - if (size == 0) { - gen_neon_dup_u8(tmp, 0); - } else if (size == 1) { - gen_neon_dup_low16(tmp); - } - for (n = 0; n <= pass * 2; n++) { - tmp2 = new_tmp(); - tcg_gen_mov_i32(tmp2, tmp); - neon_store_reg(rn, n, tmp2); - } - neon_store_reg(rn, n, tmp); - } else { - /* VMOV */ - switch (size) { - case 0: - tmp2 = neon_load_reg(rn, pass); - gen_bfi(tmp, tmp2, tmp, offset, 0xff); - dead_tmp(tmp2); - break; - case 1: - tmp2 = neon_load_reg(rn, pass); - gen_bfi(tmp, tmp2, tmp, offset, 0xffff); - dead_tmp(tmp2); - break; - case 2: - break; - } - neon_store_reg(rn, pass, tmp); - } - } - } else { /* !dp */ - if ((insn & 0x6f) != 0x00) - return 1; - rn = VFP_SREG_N(insn); - if (insn & ARM_CP_RW_BIT) { - /* vfp->arm */ - if (insn & (1 << 21)) { - /* system register */ - rn >>= 1; - - switch (rn) { - case ARM_VFP_FPSID: - /* VFP2 allows access to FSID from userspace. - VFP3 restricts all id registers to privileged - accesses. */ - if (IS_USER(s) - && arm_feature(env, ARM_FEATURE_VFP3)) - return 1; - tmp = load_cpu_field(vfp.xregs[rn]); - break; - case ARM_VFP_FPEXC: - if (IS_USER(s)) - return 1; - tmp = load_cpu_field(vfp.xregs[rn]); - break; - case ARM_VFP_FPINST: - case ARM_VFP_FPINST2: - /* Not present in VFP3. */ - if (IS_USER(s) - || arm_feature(env, ARM_FEATURE_VFP3)) - return 1; - tmp = load_cpu_field(vfp.xregs[rn]); - break; - case ARM_VFP_FPSCR: - if (rd == 15) { - tmp = load_cpu_field(vfp.xregs[ARM_VFP_FPSCR]); - tcg_gen_andi_i32(tmp, tmp, 0xf0000000); - } else { - tmp = new_tmp(); - gen_helper_vfp_get_fpscr(tmp, cpu_env); - } - break; - case ARM_VFP_MVFR0: - case ARM_VFP_MVFR1: - if (IS_USER(s) - || !arm_feature(env, ARM_FEATURE_VFP3)) - return 1; - tmp = load_cpu_field(vfp.xregs[rn]); - break; - default: - return 1; - } - } else { - gen_mov_F0_vreg(0, rn); - tmp = gen_vfp_mrs(); - } - if (rd == 15) { - /* Set the 4 flag bits in the CPSR. */ - gen_set_nzcv(tmp); - dead_tmp(tmp); - } else { - store_reg(s, rd, tmp); - } - } else { - /* arm->vfp */ - tmp = load_reg(s, rd); - if (insn & (1 << 21)) { - rn >>= 1; - /* system register */ - switch (rn) { - case ARM_VFP_FPSID: - case ARM_VFP_MVFR0: - case ARM_VFP_MVFR1: - /* Writes are ignored. */ - break; - case ARM_VFP_FPSCR: - gen_helper_vfp_set_fpscr(cpu_env, tmp); - dead_tmp(tmp); - gen_lookup_tb(s); - break; - case ARM_VFP_FPEXC: - if (IS_USER(s)) - return 1; - /* TODO: VFP subarchitecture support. - * For now, keep the EN bit only */ - tcg_gen_andi_i32(tmp, tmp, 1 << 30); - store_cpu_field(tmp, vfp.xregs[rn]); - gen_lookup_tb(s); - break; - case ARM_VFP_FPINST: - case ARM_VFP_FPINST2: - store_cpu_field(tmp, vfp.xregs[rn]); - break; - default: - return 1; - } - } else { - gen_vfp_msr(tmp); - gen_mov_vreg_F0(0, rn); - } - } - } - } else { - /* data processing */ - /* The opcode is in bits 23, 21, 20 and 6. */ - op = ((insn >> 20) & 8) | ((insn >> 19) & 6) | ((insn >> 6) & 1); - if (dp) { - if (op == 15) { - /* rn is opcode */ - rn = ((insn >> 15) & 0x1e) | ((insn >> 7) & 1); - } else { - /* rn is register number */ - VFP_DREG_N(rn, insn); - } - - if (op == 15 && (rn == 15 || rn > 17)) { - /* Integer or single precision destination. */ - rd = VFP_SREG_D(insn); - } else { - VFP_DREG_D(rd, insn); - } - - if (op == 15 && (rn == 16 || rn == 17)) { - /* Integer source. */ - rm = ((insn << 1) & 0x1e) | ((insn >> 5) & 1); - } else { - VFP_DREG_M(rm, insn); - } - } else { - rn = VFP_SREG_N(insn); - if (op == 15 && rn == 15) { - /* Double precision destination. */ - VFP_DREG_D(rd, insn); - } else { - rd = VFP_SREG_D(insn); - } - rm = VFP_SREG_M(insn); - } - - veclen = env->vfp.vec_len; - if (op == 15 && rn > 3) - veclen = 0; - - /* Shut up compiler warnings. */ - delta_m = 0; - delta_d = 0; - bank_mask = 0; - - if (veclen > 0) { - if (dp) - bank_mask = 0xc; - else - bank_mask = 0x18; - - /* Figure out what type of vector operation this is. */ - if ((rd & bank_mask) == 0) { - /* scalar */ - veclen = 0; - } else { - if (dp) - delta_d = (env->vfp.vec_stride >> 1) + 1; - else - delta_d = env->vfp.vec_stride + 1; - - if ((rm & bank_mask) == 0) { - /* mixed scalar/vector */ - delta_m = 0; - } else { - /* vector */ - delta_m = delta_d; - } - } - } - - /* Load the initial operands. */ - if (op == 15) { - switch (rn) { - case 16: - case 17: - /* Integer source */ - gen_mov_F0_vreg(0, rm); - break; - case 8: - case 9: - /* Compare */ - gen_mov_F0_vreg(dp, rd); - gen_mov_F1_vreg(dp, rm); - break; - case 10: - case 11: - /* Compare with zero */ - gen_mov_F0_vreg(dp, rd); - gen_vfp_F1_ld0(dp); - break; - case 20: - case 21: - case 22: - case 23: - case 28: - case 29: - case 30: - case 31: - /* Source and destination the same. */ - gen_mov_F0_vreg(dp, rd); - break; - default: - /* One source operand. */ - gen_mov_F0_vreg(dp, rm); - break; - } - } else { - /* Two source operands. */ - gen_mov_F0_vreg(dp, rn); - gen_mov_F1_vreg(dp, rm); - } - - for (;;) { - /* Perform the calculation. */ - switch (op) { - case 0: /* mac: fd + (fn * fm) */ - gen_vfp_mul(dp); - gen_mov_F1_vreg(dp, rd); - gen_vfp_add(dp); - break; - case 1: /* nmac: fd - (fn * fm) */ - gen_vfp_mul(dp); - gen_vfp_neg(dp); - gen_mov_F1_vreg(dp, rd); - gen_vfp_add(dp); - break; - case 2: /* msc: -fd + (fn * fm) */ - gen_vfp_mul(dp); - gen_mov_F1_vreg(dp, rd); - gen_vfp_sub(dp); - break; - case 3: /* nmsc: -fd - (fn * fm) */ - gen_vfp_mul(dp); - gen_vfp_neg(dp); - gen_mov_F1_vreg(dp, rd); - gen_vfp_sub(dp); - break; - case 4: /* mul: fn * fm */ - gen_vfp_mul(dp); - break; - case 5: /* nmul: -(fn * fm) */ - gen_vfp_mul(dp); - gen_vfp_neg(dp); - break; - case 6: /* add: fn + fm */ - gen_vfp_add(dp); - break; - case 7: /* sub: fn - fm */ - gen_vfp_sub(dp); - break; - case 8: /* div: fn / fm */ - gen_vfp_div(dp); - break; - case 14: /* fconst */ - if (!arm_feature(env, ARM_FEATURE_VFP3)) - return 1; - - n = (insn << 12) & 0x80000000; - i = ((insn >> 12) & 0x70) | (insn & 0xf); - if (dp) { - if (i & 0x40) - i |= 0x3f80; - else - i |= 0x4000; - n |= i << 16; - tcg_gen_movi_i64(cpu_F0d, ((uint64_t)n) << 32); - } else { - if (i & 0x40) - i |= 0x780; - else - i |= 0x800; - n |= i << 19; - tcg_gen_movi_i32(cpu_F0s, n); - } - break; - case 15: /* extension space */ - switch (rn) { - case 0: /* cpy */ - /* no-op */ - break; - case 1: /* abs */ - gen_vfp_abs(dp); - break; - case 2: /* neg */ - gen_vfp_neg(dp); - break; - case 3: /* sqrt */ - gen_vfp_sqrt(dp); - break; - case 4: /* vcvtb.f32.f16 */ - if (!arm_feature(env, ARM_FEATURE_VFP_FP16)) - return 1; - tmp = gen_vfp_mrs(); - tcg_gen_ext16u_i32(tmp, tmp); - gen_helper_vfp_fcvt_f16_to_f32(cpu_F0s, tmp, cpu_env); - dead_tmp(tmp); - break; - case 5: /* vcvtt.f32.f16 */ - if (!arm_feature(env, ARM_FEATURE_VFP_FP16)) - return 1; - tmp = gen_vfp_mrs(); - tcg_gen_shri_i32(tmp, tmp, 16); - gen_helper_vfp_fcvt_f16_to_f32(cpu_F0s, tmp, cpu_env); - dead_tmp(tmp); - break; - case 6: /* vcvtb.f16.f32 */ - if (!arm_feature(env, ARM_FEATURE_VFP_FP16)) - return 1; - tmp = new_tmp(); - gen_helper_vfp_fcvt_f32_to_f16(tmp, cpu_F0s, cpu_env); - gen_mov_F0_vreg(0, rd); - tmp2 = gen_vfp_mrs(); - tcg_gen_andi_i32(tmp2, tmp2, 0xffff0000); - tcg_gen_or_i32(tmp, tmp, tmp2); - dead_tmp(tmp2); - gen_vfp_msr(tmp); - break; - case 7: /* vcvtt.f16.f32 */ - if (!arm_feature(env, ARM_FEATURE_VFP_FP16)) - return 1; - tmp = new_tmp(); - gen_helper_vfp_fcvt_f32_to_f16(tmp, cpu_F0s, cpu_env); - tcg_gen_shli_i32(tmp, tmp, 16); - gen_mov_F0_vreg(0, rd); - tmp2 = gen_vfp_mrs(); - tcg_gen_ext16u_i32(tmp2, tmp2); - tcg_gen_or_i32(tmp, tmp, tmp2); - dead_tmp(tmp2); - gen_vfp_msr(tmp); - break; - case 8: /* cmp */ - gen_vfp_cmp(dp); - break; - case 9: /* cmpe */ - gen_vfp_cmpe(dp); - break; - case 10: /* cmpz */ - gen_vfp_cmp(dp); - break; - case 11: /* cmpez */ - gen_vfp_F1_ld0(dp); - gen_vfp_cmpe(dp); - break; - case 15: /* single<->double conversion */ - if (dp) - gen_helper_vfp_fcvtsd(cpu_F0s, cpu_F0d, cpu_env); - else - gen_helper_vfp_fcvtds(cpu_F0d, cpu_F0s, cpu_env); - break; - case 16: /* fuito */ - gen_vfp_uito(dp); - break; - case 17: /* fsito */ - gen_vfp_sito(dp); - break; - case 20: /* fshto */ - if (!arm_feature(env, ARM_FEATURE_VFP3)) - return 1; - gen_vfp_shto(dp, 16 - rm); - break; - case 21: /* fslto */ - if (!arm_feature(env, ARM_FEATURE_VFP3)) - return 1; - gen_vfp_slto(dp, 32 - rm); - break; - case 22: /* fuhto */ - if (!arm_feature(env, ARM_FEATURE_VFP3)) - return 1; - gen_vfp_uhto(dp, 16 - rm); - break; - case 23: /* fulto */ - if (!arm_feature(env, ARM_FEATURE_VFP3)) - return 1; - gen_vfp_ulto(dp, 32 - rm); - break; - case 24: /* ftoui */ - gen_vfp_toui(dp); - break; - case 25: /* ftouiz */ - gen_vfp_touiz(dp); - break; - case 26: /* ftosi */ - gen_vfp_tosi(dp); - break; - case 27: /* ftosiz */ - gen_vfp_tosiz(dp); - break; - case 28: /* ftosh */ - if (!arm_feature(env, ARM_FEATURE_VFP3)) - return 1; - gen_vfp_tosh(dp, 16 - rm); - break; - case 29: /* ftosl */ - if (!arm_feature(env, ARM_FEATURE_VFP3)) - return 1; - gen_vfp_tosl(dp, 32 - rm); - break; - case 30: /* ftouh */ - if (!arm_feature(env, ARM_FEATURE_VFP3)) - return 1; - gen_vfp_touh(dp, 16 - rm); - break; - case 31: /* ftoul */ - if (!arm_feature(env, ARM_FEATURE_VFP3)) - return 1; - gen_vfp_toul(dp, 32 - rm); - break; - default: /* undefined */ - printf ("rn:%d\n", rn); - return 1; - } - break; - default: /* undefined */ - printf ("op:%d\n", op); - return 1; - } - - /* Write back the result. */ - if (op == 15 && (rn >= 8 && rn <= 11)) - ; /* Comparison, do nothing. */ - else if (op == 15 && rn > 17) - /* Integer result. */ - gen_mov_vreg_F0(0, rd); - else if (op == 15 && rn == 15) - /* conversion */ - gen_mov_vreg_F0(!dp, rd); - else - gen_mov_vreg_F0(dp, rd); - - /* break out of the loop if we have finished */ - if (veclen == 0) - break; - - if (op == 15 && delta_m == 0) { - /* single source one-many */ - while (veclen--) { - rd = ((rd + delta_d) & (bank_mask - 1)) - | (rd & bank_mask); - gen_mov_vreg_F0(dp, rd); - } - break; - } - /* Setup the next operands. */ - veclen--; - rd = ((rd + delta_d) & (bank_mask - 1)) - | (rd & bank_mask); - - if (op == 15) { - /* One source operand. */ - rm = ((rm + delta_m) & (bank_mask - 1)) - | (rm & bank_mask); - gen_mov_F0_vreg(dp, rm); - } else { - /* Two source operands. */ - rn = ((rn + delta_d) & (bank_mask - 1)) - | (rn & bank_mask); - gen_mov_F0_vreg(dp, rn); - if (delta_m) { - rm = ((rm + delta_m) & (bank_mask - 1)) - | (rm & bank_mask); - gen_mov_F1_vreg(dp, rm); - } - } - } - } - break; - case 0xc: - case 0xd: - if (dp && (insn & 0x03e00000) == 0x00400000) { - /* two-register transfer */ - rn = (insn >> 16) & 0xf; - rd = (insn >> 12) & 0xf; - if (dp) { - VFP_DREG_M(rm, insn); - } else { - rm = VFP_SREG_M(insn); - } - - if (insn & ARM_CP_RW_BIT) { - /* vfp->arm */ - if (dp) { - gen_mov_F0_vreg(0, rm * 2); - tmp = gen_vfp_mrs(); - store_reg(s, rd, tmp); - gen_mov_F0_vreg(0, rm * 2 + 1); - tmp = gen_vfp_mrs(); - store_reg(s, rn, tmp); - } else { - gen_mov_F0_vreg(0, rm); - tmp = gen_vfp_mrs(); - store_reg(s, rn, tmp); - gen_mov_F0_vreg(0, rm + 1); - tmp = gen_vfp_mrs(); - store_reg(s, rd, tmp); - } - } else { - /* arm->vfp */ - if (dp) { - tmp = load_reg(s, rd); - gen_vfp_msr(tmp); - gen_mov_vreg_F0(0, rm * 2); - tmp = load_reg(s, rn); - gen_vfp_msr(tmp); - gen_mov_vreg_F0(0, rm * 2 + 1); - } else { - tmp = load_reg(s, rn); - gen_vfp_msr(tmp); - gen_mov_vreg_F0(0, rm); - tmp = load_reg(s, rd); - gen_vfp_msr(tmp); - gen_mov_vreg_F0(0, rm + 1); - } - } - } else { - /* Load/store */ - rn = (insn >> 16) & 0xf; - if (dp) - VFP_DREG_D(rd, insn); - else - rd = VFP_SREG_D(insn); - if (s->thumb && rn == 15) { - addr = new_tmp(); - tcg_gen_movi_i32(addr, s->pc & ~2); - } else { - addr = load_reg(s, rn); - } - if ((insn & 0x01200000) == 0x01000000) { - /* Single load/store */ - offset = (insn & 0xff) << 2; - if ((insn & (1 << 23)) == 0) - offset = -offset; - tcg_gen_addi_i32(addr, addr, offset); - if (insn & (1 << 20)) { - gen_vfp_ld(s, dp, addr); - gen_mov_vreg_F0(dp, rd); - } else { - gen_mov_F0_vreg(dp, rd); - gen_vfp_st(s, dp, addr); - } - dead_tmp(addr); - } else { - /* load/store multiple */ - if (dp) - n = (insn >> 1) & 0x7f; - else - n = insn & 0xff; - - if (insn & (1 << 24)) /* pre-decrement */ - tcg_gen_addi_i32(addr, addr, -((insn & 0xff) << 2)); - - if (dp) - offset = 8; - else - offset = 4; - for (i = 0; i < n; i++) { - if (insn & ARM_CP_RW_BIT) { - /* load */ - gen_vfp_ld(s, dp, addr); - gen_mov_vreg_F0(dp, rd + i); - } else { - /* store */ - gen_mov_F0_vreg(dp, rd + i); - gen_vfp_st(s, dp, addr); - } - tcg_gen_addi_i32(addr, addr, offset); - } - if (insn & (1 << 21)) { - /* writeback */ - if (insn & (1 << 24)) - offset = -offset * n; - else if (dp && (insn & 1)) - offset = 4; - else - offset = 0; - - if (offset != 0) - tcg_gen_addi_i32(addr, addr, offset); - store_reg(s, rn, addr); - } else { - dead_tmp(addr); - } - } - } - break; - default: - /* Should never happen. */ - return 1; - } - return 0; -} - -static inline void gen_goto_tb(DisasContext *s, int n, uint32_t dest) -{ - TranslationBlock *tb; - - tb = s->tb; - if ((tb->pc & TARGET_PAGE_MASK) == (dest & TARGET_PAGE_MASK)) { - tcg_gen_goto_tb(n); - gen_set_pc_im(dest); - tcg_gen_exit_tb((long)tb + n); - } else { - gen_set_pc_im(dest); - tcg_gen_exit_tb(0); - } -} - -static inline void gen_jmp (DisasContext *s, uint32_t dest) -{ - if (unlikely(s->singlestep_enabled)) { - /* An indirect jump so that we still trigger the debug exception. */ - if (s->thumb) - dest |= 1; - gen_bx_im(s, dest); - } else { - gen_goto_tb(s, 0, dest); - s->is_jmp = DISAS_TB_JUMP; - } -} - -static inline void gen_mulxy(TCGv t0, TCGv t1, int x, int y) -{ - if (x) - tcg_gen_sari_i32(t0, t0, 16); - else - gen_sxth(t0); - if (y) - tcg_gen_sari_i32(t1, t1, 16); - else - gen_sxth(t1); - tcg_gen_mul_i32(t0, t0, t1); -} - -/* Return the mask of PSR bits set by a MSR instruction. */ -static uint32_t msr_mask(CPUState *env, DisasContext *s, int flags, int spsr) { - uint32_t mask; - - mask = 0; - if (flags & (1 << 0)) - mask |= 0xff; - if (flags & (1 << 1)) - mask |= 0xff00; - if (flags & (1 << 2)) - mask |= 0xff0000; - if (flags & (1 << 3)) - mask |= 0xff000000; - - /* Mask out undefined bits. */ - mask &= ~CPSR_RESERVED; - if (!arm_feature(env, ARM_FEATURE_V6)) - mask &= ~(CPSR_E | CPSR_GE); - if (!arm_feature(env, ARM_FEATURE_THUMB2)) - mask &= ~CPSR_IT; - /* Mask out execution state bits. */ - if (!spsr) - mask &= ~CPSR_EXEC; - /* Mask out privileged bits. */ - if (IS_USER(s)) - mask &= CPSR_USER; - return mask; -} - -/* Returns nonzero if access to the PSR is not permitted. Marks t0 as dead. */ -static int gen_set_psr(DisasContext *s, uint32_t mask, int spsr, TCGv t0) -{ - TCGv tmp; - if (spsr) { - /* ??? This is also undefined in system mode. */ - if (IS_USER(s)) - return 1; - - tmp = load_cpu_field(spsr); - tcg_gen_andi_i32(tmp, tmp, ~mask); - tcg_gen_andi_i32(t0, t0, mask); - tcg_gen_or_i32(tmp, tmp, t0); - store_cpu_field(tmp, spsr); - } else { - gen_set_cpsr(t0, mask); - } - dead_tmp(t0); - gen_lookup_tb(s); - return 0; -} - -/* Returns nonzero if access to the PSR is not permitted. */ -static int gen_set_psr_im(DisasContext *s, uint32_t mask, int spsr, uint32_t val) -{ - TCGv tmp; - tmp = new_tmp(); - tcg_gen_movi_i32(tmp, val); - return gen_set_psr(s, mask, spsr, tmp); -} - -/* Generate an old-style exception return. Marks pc as dead. */ -static void gen_exception_return(DisasContext *s, TCGv pc) -{ - TCGv tmp; - store_reg(s, 15, pc); - tmp = load_cpu_field(spsr); - gen_set_cpsr(tmp, 0xffffffff); - dead_tmp(tmp); - s->is_jmp = DISAS_UPDATE; -} - -/* Generate a v6 exception return. Marks both values as dead. */ -static void gen_rfe(DisasContext *s, TCGv pc, TCGv cpsr) -{ - gen_set_cpsr(cpsr, 0xffffffff); - dead_tmp(cpsr); - store_reg(s, 15, pc); - s->is_jmp = DISAS_UPDATE; -} - -static inline void -gen_set_condexec (DisasContext *s) -{ - if (s->condexec_mask) { - uint32_t val = (s->condexec_cond << 4) | (s->condexec_mask >> 1); - TCGv tmp = new_tmp(); - tcg_gen_movi_i32(tmp, val); - store_cpu_field(tmp, condexec_bits); - } -} - -static void gen_nop_hint(DisasContext *s, int val) -{ - switch (val) { - case 3: /* wfi */ - gen_set_pc_im(s->pc); - s->is_jmp = DISAS_WFI; - break; - case 2: /* wfe */ - case 4: /* sev */ - /* TODO: Implement SEV and WFE. May help SMP performance. */ - default: /* nop */ - break; - } -} - -#define CPU_V001 cpu_V0, cpu_V0, cpu_V1 - -static inline int gen_neon_add(int size, TCGv t0, TCGv t1) -{ - switch (size) { - case 0: gen_helper_neon_add_u8(t0, t0, t1); break; - case 1: gen_helper_neon_add_u16(t0, t0, t1); break; - case 2: tcg_gen_add_i32(t0, t0, t1); break; - default: return 1; - } - return 0; -} - -static inline void gen_neon_rsb(int size, TCGv t0, TCGv t1) -{ - switch (size) { - case 0: gen_helper_neon_sub_u8(t0, t1, t0); break; - case 1: gen_helper_neon_sub_u16(t0, t1, t0); break; - case 2: tcg_gen_sub_i32(t0, t1, t0); break; - default: return; - } -} - -/* 32-bit pairwise ops end up the same as the elementwise versions. */ -#define gen_helper_neon_pmax_s32 gen_helper_neon_max_s32 -#define gen_helper_neon_pmax_u32 gen_helper_neon_max_u32 -#define gen_helper_neon_pmin_s32 gen_helper_neon_min_s32 -#define gen_helper_neon_pmin_u32 gen_helper_neon_min_u32 - -/* FIXME: This is wrong. They set the wrong overflow bit. */ -#define gen_helper_neon_qadd_s32(a, e, b, c) gen_helper_add_saturate(a, b, c) -#define gen_helper_neon_qadd_u32(a, e, b, c) gen_helper_add_usaturate(a, b, c) -#define gen_helper_neon_qsub_s32(a, e, b, c) gen_helper_sub_saturate(a, b, c) -#define gen_helper_neon_qsub_u32(a, e, b, c) gen_helper_sub_usaturate(a, b, c) - -#define GEN_NEON_INTEGER_OP_ENV(name) do { \ - switch ((size << 1) | u) { \ - case 0: \ - gen_helper_neon_##name##_s8(tmp, cpu_env, tmp, tmp2); \ - break; \ - case 1: \ - gen_helper_neon_##name##_u8(tmp, cpu_env, tmp, tmp2); \ - break; \ - case 2: \ - gen_helper_neon_##name##_s16(tmp, cpu_env, tmp, tmp2); \ - break; \ - case 3: \ - gen_helper_neon_##name##_u16(tmp, cpu_env, tmp, tmp2); \ - break; \ - case 4: \ - gen_helper_neon_##name##_s32(tmp, cpu_env, tmp, tmp2); \ - break; \ - case 5: \ - gen_helper_neon_##name##_u32(tmp, cpu_env, tmp, tmp2); \ - break; \ - default: return 1; \ - }} while (0) - -#define GEN_NEON_INTEGER_OP(name) do { \ - switch ((size << 1) | u) { \ - case 0: \ - gen_helper_neon_##name##_s8(tmp, tmp, tmp2); \ - break; \ - case 1: \ - gen_helper_neon_##name##_u8(tmp, tmp, tmp2); \ - break; \ - case 2: \ - gen_helper_neon_##name##_s16(tmp, tmp, tmp2); \ - break; \ - case 3: \ - gen_helper_neon_##name##_u16(tmp, tmp, tmp2); \ - break; \ - case 4: \ - gen_helper_neon_##name##_s32(tmp, tmp, tmp2); \ - break; \ - case 5: \ - gen_helper_neon_##name##_u32(tmp, tmp, tmp2); \ - break; \ - default: return 1; \ - }} while (0) - -static TCGv neon_load_scratch(int scratch) -{ - TCGv tmp = new_tmp(); - tcg_gen_ld_i32(tmp, cpu_env, offsetof(CPUARMState, vfp.scratch[scratch])); - return tmp; -} - -static void neon_store_scratch(int scratch, TCGv var) -{ - tcg_gen_st_i32(var, cpu_env, offsetof(CPUARMState, vfp.scratch[scratch])); - dead_tmp(var); -} - -static inline TCGv neon_get_scalar(int size, int reg) -{ - TCGv tmp; - if (size == 1) { - tmp = neon_load_reg(reg >> 1, reg & 1); - } else { - tmp = neon_load_reg(reg >> 2, (reg >> 1) & 1); - if (reg & 1) { - gen_neon_dup_low16(tmp); - } else { - gen_neon_dup_high16(tmp); - } - } - return tmp; -} - -static void gen_neon_unzip_u8(TCGv t0, TCGv t1) -{ - TCGv rd, rm, tmp; - - rd = new_tmp(); - rm = new_tmp(); - tmp = new_tmp(); - - tcg_gen_andi_i32(rd, t0, 0xff); - tcg_gen_shri_i32(tmp, t0, 8); - tcg_gen_andi_i32(tmp, tmp, 0xff00); - tcg_gen_or_i32(rd, rd, tmp); - tcg_gen_shli_i32(tmp, t1, 16); - tcg_gen_andi_i32(tmp, tmp, 0xff0000); - tcg_gen_or_i32(rd, rd, tmp); - tcg_gen_shli_i32(tmp, t1, 8); - tcg_gen_andi_i32(tmp, tmp, 0xff000000); - tcg_gen_or_i32(rd, rd, tmp); - - tcg_gen_shri_i32(rm, t0, 8); - tcg_gen_andi_i32(rm, rm, 0xff); - tcg_gen_shri_i32(tmp, t0, 16); - tcg_gen_andi_i32(tmp, tmp, 0xff00); - tcg_gen_or_i32(rm, rm, tmp); - tcg_gen_shli_i32(tmp, t1, 8); - tcg_gen_andi_i32(tmp, tmp, 0xff0000); - tcg_gen_or_i32(rm, rm, tmp); - tcg_gen_andi_i32(tmp, t1, 0xff000000); - tcg_gen_or_i32(t1, rm, tmp); - tcg_gen_mov_i32(t0, rd); - - dead_tmp(tmp); - dead_tmp(rm); - dead_tmp(rd); -} - -static void gen_neon_zip_u8(TCGv t0, TCGv t1) -{ - TCGv rd, rm, tmp; - - rd = new_tmp(); - rm = new_tmp(); - tmp = new_tmp(); - - tcg_gen_andi_i32(rd, t0, 0xff); - tcg_gen_shli_i32(tmp, t1, 8); - tcg_gen_andi_i32(tmp, tmp, 0xff00); - tcg_gen_or_i32(rd, rd, tmp); - tcg_gen_shli_i32(tmp, t0, 16); - tcg_gen_andi_i32(tmp, tmp, 0xff0000); - tcg_gen_or_i32(rd, rd, tmp); - tcg_gen_shli_i32(tmp, t1, 24); - tcg_gen_andi_i32(tmp, tmp, 0xff000000); - tcg_gen_or_i32(rd, rd, tmp); - - tcg_gen_andi_i32(rm, t1, 0xff000000); - tcg_gen_shri_i32(tmp, t0, 8); - tcg_gen_andi_i32(tmp, tmp, 0xff0000); - tcg_gen_or_i32(rm, rm, tmp); - tcg_gen_shri_i32(tmp, t1, 8); - tcg_gen_andi_i32(tmp, tmp, 0xff00); - tcg_gen_or_i32(rm, rm, tmp); - tcg_gen_shri_i32(tmp, t0, 16); - tcg_gen_andi_i32(tmp, tmp, 0xff); - tcg_gen_or_i32(t1, rm, tmp); - tcg_gen_mov_i32(t0, rd); - - dead_tmp(tmp); - dead_tmp(rm); - dead_tmp(rd); -} - -static void gen_neon_zip_u16(TCGv t0, TCGv t1) -{ - TCGv tmp, tmp2; - - tmp = new_tmp(); - tmp2 = new_tmp(); - - tcg_gen_andi_i32(tmp, t0, 0xffff); - tcg_gen_shli_i32(tmp2, t1, 16); - tcg_gen_or_i32(tmp, tmp, tmp2); - tcg_gen_andi_i32(t1, t1, 0xffff0000); - tcg_gen_shri_i32(tmp2, t0, 16); - tcg_gen_or_i32(t1, t1, tmp2); - tcg_gen_mov_i32(t0, tmp); - - dead_tmp(tmp2); - dead_tmp(tmp); -} - -static void gen_neon_unzip(int reg, int q, int tmp, int size) -{ - int n; - TCGv t0, t1; - - for (n = 0; n < q + 1; n += 2) { - t0 = neon_load_reg(reg, n); - t1 = neon_load_reg(reg, n + 1); - switch (size) { - case 0: gen_neon_unzip_u8(t0, t1); break; - case 1: gen_neon_zip_u16(t0, t1); break; /* zip and unzip are the same. */ - case 2: /* no-op */; break; - default: abort(); - } - neon_store_scratch(tmp + n, t0); - neon_store_scratch(tmp + n + 1, t1); - } -} - -static void gen_neon_trn_u8(TCGv t0, TCGv t1) -{ - TCGv rd, tmp; - - rd = new_tmp(); - tmp = new_tmp(); - - tcg_gen_shli_i32(rd, t0, 8); - tcg_gen_andi_i32(rd, rd, 0xff00ff00); - tcg_gen_andi_i32(tmp, t1, 0x00ff00ff); - tcg_gen_or_i32(rd, rd, tmp); - - tcg_gen_shri_i32(t1, t1, 8); - tcg_gen_andi_i32(t1, t1, 0x00ff00ff); - tcg_gen_andi_i32(tmp, t0, 0xff00ff00); - tcg_gen_or_i32(t1, t1, tmp); - tcg_gen_mov_i32(t0, rd); - - dead_tmp(tmp); - dead_tmp(rd); -} - -static void gen_neon_trn_u16(TCGv t0, TCGv t1) -{ - TCGv rd, tmp; - - rd = new_tmp(); - tmp = new_tmp(); - - tcg_gen_shli_i32(rd, t0, 16); - tcg_gen_andi_i32(tmp, t1, 0xffff); - tcg_gen_or_i32(rd, rd, tmp); - tcg_gen_shri_i32(t1, t1, 16); - tcg_gen_andi_i32(tmp, t0, 0xffff0000); - tcg_gen_or_i32(t1, t1, tmp); - tcg_gen_mov_i32(t0, rd); - - dead_tmp(tmp); - dead_tmp(rd); -} - - -static struct { - int nregs; - int interleave; - int spacing; -} neon_ls_element_type[11] = { - {4, 4, 1}, - {4, 4, 2}, - {4, 1, 1}, - {4, 2, 1}, - {3, 3, 1}, - {3, 3, 2}, - {3, 1, 1}, - {1, 1, 1}, - {2, 2, 1}, - {2, 2, 2}, - {2, 1, 1} -}; - -/* Translate a NEON load/store element instruction. Return nonzero if the - instruction is invalid. */ -static int disas_neon_ls_insn(CPUState * env, DisasContext *s, uint32_t insn) -{ - int rd, rn, rm; - int op; - int nregs; - int interleave; - int spacing; - int stride; - int size; - int reg; - int pass; - int load; - int shift; - int n; - TCGv addr; - TCGv tmp; - TCGv tmp2; - TCGv_i64 tmp64; - - if (!vfp_enabled(env)) - return 1; - VFP_DREG_D(rd, insn); - rn = (insn >> 16) & 0xf; - rm = insn & 0xf; - load = (insn & (1 << 21)) != 0; - addr = new_tmp(); - if ((insn & (1 << 23)) == 0) { - /* Load store all elements. */ - op = (insn >> 8) & 0xf; - size = (insn >> 6) & 3; - if (op > 10) - return 1; - nregs = neon_ls_element_type[op].nregs; - interleave = neon_ls_element_type[op].interleave; - spacing = neon_ls_element_type[op].spacing; - if (size == 3 && (interleave | spacing) != 1) - return 1; - load_reg_var(s, addr, rn); - stride = (1 << size) * interleave; - for (reg = 0; reg < nregs; reg++) { - if (interleave > 2 || (interleave == 2 && nregs == 2)) { - load_reg_var(s, addr, rn); - tcg_gen_addi_i32(addr, addr, (1 << size) * reg); - } else if (interleave == 2 && nregs == 4 && reg == 2) { - load_reg_var(s, addr, rn); - tcg_gen_addi_i32(addr, addr, 1 << size); - } - if (size == 3) { - if (load) { - tmp64 = gen_ld64(addr, IS_USER(s)); - neon_store_reg64(tmp64, rd); - tcg_temp_free_i64(tmp64); - } else { - tmp64 = tcg_temp_new_i64(); - neon_load_reg64(tmp64, rd); - gen_st64(tmp64, addr, IS_USER(s)); - } - tcg_gen_addi_i32(addr, addr, stride); - } else { - for (pass = 0; pass < 2; pass++) { - if (size == 2) { - if (load) { - tmp = gen_ld32(addr, IS_USER(s)); - neon_store_reg(rd, pass, tmp); - } else { - tmp = neon_load_reg(rd, pass); - gen_st32(tmp, addr, IS_USER(s)); - } - tcg_gen_addi_i32(addr, addr, stride); - } else if (size == 1) { - if (load) { - tmp = gen_ld16u(addr, IS_USER(s)); - tcg_gen_addi_i32(addr, addr, stride); - tmp2 = gen_ld16u(addr, IS_USER(s)); - tcg_gen_addi_i32(addr, addr, stride); - gen_bfi(tmp, tmp, tmp2, 16, 0xffff); - dead_tmp(tmp2); - neon_store_reg(rd, pass, tmp); - } else { - tmp = neon_load_reg(rd, pass); - tmp2 = new_tmp(); - tcg_gen_shri_i32(tmp2, tmp, 16); - gen_st16(tmp, addr, IS_USER(s)); - tcg_gen_addi_i32(addr, addr, stride); - gen_st16(tmp2, addr, IS_USER(s)); - tcg_gen_addi_i32(addr, addr, stride); - } - } else /* size == 0 */ { - if (load) { - TCGV_UNUSED(tmp2); - for (n = 0; n < 4; n++) { - tmp = gen_ld8u(addr, IS_USER(s)); - tcg_gen_addi_i32(addr, addr, stride); - if (n == 0) { - tmp2 = tmp; - } else { - gen_bfi(tmp2, tmp2, tmp, n * 8, 0xff); - dead_tmp(tmp); - } - } - neon_store_reg(rd, pass, tmp2); - } else { - tmp2 = neon_load_reg(rd, pass); - for (n = 0; n < 4; n++) { - tmp = new_tmp(); - if (n == 0) { - tcg_gen_mov_i32(tmp, tmp2); - } else { - tcg_gen_shri_i32(tmp, tmp2, n * 8); - } - gen_st8(tmp, addr, IS_USER(s)); - tcg_gen_addi_i32(addr, addr, stride); - } - dead_tmp(tmp2); - } - } - } - } - rd += spacing; - } - stride = nregs * 8; - } else { - size = (insn >> 10) & 3; - if (size == 3) { - /* Load single element to all lanes. */ - if (!load) - return 1; - size = (insn >> 6) & 3; - nregs = ((insn >> 8) & 3) + 1; - stride = (insn & (1 << 5)) ? 2 : 1; - load_reg_var(s, addr, rn); - for (reg = 0; reg < nregs; reg++) { - switch (size) { - case 0: - tmp = gen_ld8u(addr, IS_USER(s)); - gen_neon_dup_u8(tmp, 0); - break; - case 1: - tmp = gen_ld16u(addr, IS_USER(s)); - gen_neon_dup_low16(tmp); - break; - case 2: - tmp = gen_ld32(addr, IS_USER(s)); - break; - case 3: - return 1; - default: /* Avoid compiler warnings. */ - abort(); - } - tcg_gen_addi_i32(addr, addr, 1 << size); - tmp2 = new_tmp(); - tcg_gen_mov_i32(tmp2, tmp); - neon_store_reg(rd, 0, tmp2); - neon_store_reg(rd, 1, tmp); - rd += stride; - } - stride = (1 << size) * nregs; - } else { - /* Single element. */ - pass = (insn >> 7) & 1; - switch (size) { - case 0: - shift = ((insn >> 5) & 3) * 8; - stride = 1; - break; - case 1: - shift = ((insn >> 6) & 1) * 16; - stride = (insn & (1 << 5)) ? 2 : 1; - break; - case 2: - shift = 0; - stride = (insn & (1 << 6)) ? 2 : 1; - break; - default: - abort(); - } - nregs = ((insn >> 8) & 3) + 1; - load_reg_var(s, addr, rn); - for (reg = 0; reg < nregs; reg++) { - if (load) { - switch (size) { - case 0: - tmp = gen_ld8u(addr, IS_USER(s)); - break; - case 1: - tmp = gen_ld16u(addr, IS_USER(s)); - break; - case 2: - tmp = gen_ld32(addr, IS_USER(s)); - break; - default: /* Avoid compiler warnings. */ - abort(); - } - if (size != 2) { - tmp2 = neon_load_reg(rd, pass); - gen_bfi(tmp, tmp2, tmp, shift, size ? 0xffff : 0xff); - dead_tmp(tmp2); - } - neon_store_reg(rd, pass, tmp); - } else { /* Store */ - tmp = neon_load_reg(rd, pass); - if (shift) - tcg_gen_shri_i32(tmp, tmp, shift); - switch (size) { - case 0: - gen_st8(tmp, addr, IS_USER(s)); - break; - case 1: - gen_st16(tmp, addr, IS_USER(s)); - break; - case 2: - gen_st32(tmp, addr, IS_USER(s)); - break; - } - } - rd += stride; - tcg_gen_addi_i32(addr, addr, 1 << size); - } - stride = nregs * (1 << size); - } - } - dead_tmp(addr); - if (rm != 15) { - TCGv base; - - base = load_reg(s, rn); - if (rm == 13) { - tcg_gen_addi_i32(base, base, stride); - } else { - TCGv index; - index = load_reg(s, rm); - tcg_gen_add_i32(base, base, index); - dead_tmp(index); - } - store_reg(s, rn, base); - } - return 0; -} - -/* Bitwise select. dest = c ? t : f. Clobbers T and F. */ -static void gen_neon_bsl(TCGv dest, TCGv t, TCGv f, TCGv c) -{ - tcg_gen_and_i32(t, t, c); - tcg_gen_andc_i32(f, f, c); - tcg_gen_or_i32(dest, t, f); -} - -static inline void gen_neon_narrow(int size, TCGv dest, TCGv_i64 src) -{ - switch (size) { - case 0: gen_helper_neon_narrow_u8(dest, src); break; - case 1: gen_helper_neon_narrow_u16(dest, src); break; - case 2: tcg_gen_trunc_i64_i32(dest, src); break; - default: abort(); - } -} - -static inline void gen_neon_narrow_sats(int size, TCGv dest, TCGv_i64 src) -{ - switch (size) { - case 0: gen_helper_neon_narrow_sat_s8(dest, cpu_env, src); break; - case 1: gen_helper_neon_narrow_sat_s16(dest, cpu_env, src); break; - case 2: gen_helper_neon_narrow_sat_s32(dest, cpu_env, src); break; - default: abort(); - } -} - -static inline void gen_neon_narrow_satu(int size, TCGv dest, TCGv_i64 src) -{ - switch (size) { - case 0: gen_helper_neon_narrow_sat_u8(dest, cpu_env, src); break; - case 1: gen_helper_neon_narrow_sat_u16(dest, cpu_env, src); break; - case 2: gen_helper_neon_narrow_sat_u32(dest, cpu_env, src); break; - default: abort(); - } -} - -static inline void gen_neon_shift_narrow(int size, TCGv var, TCGv shift, - int q, int u) -{ - if (q) { - if (u) { - switch (size) { - case 1: gen_helper_neon_rshl_u16(var, var, shift); break; - case 2: gen_helper_neon_rshl_u32(var, var, shift); break; - default: abort(); - } - } else { - switch (size) { - case 1: gen_helper_neon_rshl_s16(var, var, shift); break; - case 2: gen_helper_neon_rshl_s32(var, var, shift); break; - default: abort(); - } - } - } else { - if (u) { - switch (size) { - case 1: gen_helper_neon_rshl_u16(var, var, shift); break; - case 2: gen_helper_neon_rshl_u32(var, var, shift); break; - default: abort(); - } - } else { - switch (size) { - case 1: gen_helper_neon_shl_s16(var, var, shift); break; - case 2: gen_helper_neon_shl_s32(var, var, shift); break; - default: abort(); - } - } - } -} - -static inline void gen_neon_widen(TCGv_i64 dest, TCGv src, int size, int u) -{ - if (u) { - switch (size) { - case 0: gen_helper_neon_widen_u8(dest, src); break; - case 1: gen_helper_neon_widen_u16(dest, src); break; - case 2: tcg_gen_extu_i32_i64(dest, src); break; - default: abort(); - } - } else { - switch (size) { - case 0: gen_helper_neon_widen_s8(dest, src); break; - case 1: gen_helper_neon_widen_s16(dest, src); break; - case 2: tcg_gen_ext_i32_i64(dest, src); break; - default: abort(); - } - } - dead_tmp(src); -} - -static inline void gen_neon_addl(int size) -{ - switch (size) { - case 0: gen_helper_neon_addl_u16(CPU_V001); break; - case 1: gen_helper_neon_addl_u32(CPU_V001); break; - case 2: tcg_gen_add_i64(CPU_V001); break; - default: abort(); - } -} - -static inline void gen_neon_subl(int size) -{ - switch (size) { - case 0: gen_helper_neon_subl_u16(CPU_V001); break; - case 1: gen_helper_neon_subl_u32(CPU_V001); break; - case 2: tcg_gen_sub_i64(CPU_V001); break; - default: abort(); - } -} - -static inline void gen_neon_negl(TCGv_i64 var, int size) -{ - switch (size) { - case 0: gen_helper_neon_negl_u16(var, var); break; - case 1: gen_helper_neon_negl_u32(var, var); break; - case 2: gen_helper_neon_negl_u64(var, var); break; - default: abort(); - } -} - -static inline void gen_neon_addl_saturate(TCGv_i64 op0, TCGv_i64 op1, int size) -{ - switch (size) { - case 1: gen_helper_neon_addl_saturate_s32(op0, cpu_env, op0, op1); break; - case 2: gen_helper_neon_addl_saturate_s64(op0, cpu_env, op0, op1); break; - default: abort(); - } -} - -static inline void gen_neon_mull(TCGv_i64 dest, TCGv a, TCGv b, int size, int u) -{ - TCGv_i64 tmp; - - switch ((size << 1) | u) { - case 0: gen_helper_neon_mull_s8(dest, a, b); break; - case 1: gen_helper_neon_mull_u8(dest, a, b); break; - case 2: gen_helper_neon_mull_s16(dest, a, b); break; - case 3: gen_helper_neon_mull_u16(dest, a, b); break; - case 4: - tmp = gen_muls_i64_i32(a, b); - tcg_gen_mov_i64(dest, tmp); - break; - case 5: - tmp = gen_mulu_i64_i32(a, b); - tcg_gen_mov_i64(dest, tmp); - break; - default: abort(); - } -} - -/* Translate a NEON data processing instruction. Return nonzero if the - instruction is invalid. - We process data in a mixture of 32-bit and 64-bit chunks. - Mostly we use 32-bit chunks so we can use normal scalar instructions. */ - -static int disas_neon_data_insn(CPUState * env, DisasContext *s, uint32_t insn) -{ - int op; - int q; - int rd, rn, rm; - int size; - int shift; - int pass; - int count; - int pairwise; - int u; - int n; - uint32_t imm, mask; - TCGv tmp, tmp2, tmp3, tmp4, tmp5; - TCGv_i64 tmp64; - - if (!vfp_enabled(env)) - return 1; - q = (insn & (1 << 6)) != 0; - u = (insn >> 24) & 1; - VFP_DREG_D(rd, insn); - VFP_DREG_N(rn, insn); - VFP_DREG_M(rm, insn); - size = (insn >> 20) & 3; - if ((insn & (1 << 23)) == 0) { - /* Three register same length. */ - op = ((insn >> 7) & 0x1e) | ((insn >> 4) & 1); - if (size == 3 && (op == 1 || op == 5 || op == 8 || op == 9 - || op == 10 || op == 11 || op == 16)) { - /* 64-bit element instructions. */ - for (pass = 0; pass < (q ? 2 : 1); pass++) { - neon_load_reg64(cpu_V0, rn + pass); - neon_load_reg64(cpu_V1, rm + pass); - switch (op) { - case 1: /* VQADD */ - if (u) { - gen_helper_neon_add_saturate_u64(CPU_V001); - } else { - gen_helper_neon_add_saturate_s64(CPU_V001); - } - break; - case 5: /* VQSUB */ - if (u) { - gen_helper_neon_sub_saturate_u64(CPU_V001); - } else { - gen_helper_neon_sub_saturate_s64(CPU_V001); - } - break; - case 8: /* VSHL */ - if (u) { - gen_helper_neon_shl_u64(cpu_V0, cpu_V1, cpu_V0); - } else { - gen_helper_neon_shl_s64(cpu_V0, cpu_V1, cpu_V0); - } - break; - case 9: /* VQSHL */ - if (u) { - gen_helper_neon_qshl_u64(cpu_V0, cpu_env, - cpu_V0, cpu_V0); - } else { - gen_helper_neon_qshl_s64(cpu_V1, cpu_env, - cpu_V1, cpu_V0); - } - break; - case 10: /* VRSHL */ - if (u) { - gen_helper_neon_rshl_u64(cpu_V0, cpu_V1, cpu_V0); - } else { - gen_helper_neon_rshl_s64(cpu_V0, cpu_V1, cpu_V0); - } - break; - case 11: /* VQRSHL */ - if (u) { - gen_helper_neon_qrshl_u64(cpu_V0, cpu_env, - cpu_V1, cpu_V0); - } else { - gen_helper_neon_qrshl_s64(cpu_V0, cpu_env, - cpu_V1, cpu_V0); - } - break; - case 16: - if (u) { - tcg_gen_sub_i64(CPU_V001); - } else { - tcg_gen_add_i64(CPU_V001); - } - break; - default: - abort(); - } - neon_store_reg64(cpu_V0, rd + pass); - } - return 0; - } - switch (op) { - case 8: /* VSHL */ - case 9: /* VQSHL */ - case 10: /* VRSHL */ - case 11: /* VQRSHL */ - { - int rtmp; - /* Shift instruction operands are reversed. */ - rtmp = rn; - rn = rm; - rm = rtmp; - pairwise = 0; - } - break; - case 20: /* VPMAX */ - case 21: /* VPMIN */ - case 23: /* VPADD */ - pairwise = 1; - break; - case 26: /* VPADD (float) */ - pairwise = (u && size < 2); - break; - case 30: /* VPMIN/VPMAX (float) */ - pairwise = u; - break; - default: - pairwise = 0; - break; - } - - for (pass = 0; pass < (q ? 4 : 2); pass++) { - - if (pairwise) { - /* Pairwise. */ - if (q) - n = (pass & 1) * 2; - else - n = 0; - if (pass < q + 1) { - tmp = neon_load_reg(rn, n); - tmp2 = neon_load_reg(rn, n + 1); - } else { - tmp = neon_load_reg(rm, n); - tmp2 = neon_load_reg(rm, n + 1); - } - } else { - /* Elementwise. */ - tmp = neon_load_reg(rn, pass); - tmp2 = neon_load_reg(rm, pass); - } - switch (op) { - case 0: /* VHADD */ - GEN_NEON_INTEGER_OP(hadd); - break; - case 1: /* VQADD */ - GEN_NEON_INTEGER_OP_ENV(qadd); - break; - case 2: /* VRHADD */ - GEN_NEON_INTEGER_OP(rhadd); - break; - case 3: /* Logic ops. */ - switch ((u << 2) | size) { - case 0: /* VAND */ - tcg_gen_and_i32(tmp, tmp, tmp2); - break; - case 1: /* BIC */ - tcg_gen_andc_i32(tmp, tmp, tmp2); - break; - case 2: /* VORR */ - tcg_gen_or_i32(tmp, tmp, tmp2); - break; - case 3: /* VORN */ - tcg_gen_orc_i32(tmp, tmp, tmp2); - break; - case 4: /* VEOR */ - tcg_gen_xor_i32(tmp, tmp, tmp2); - break; - case 5: /* VBSL */ - tmp3 = neon_load_reg(rd, pass); - gen_neon_bsl(tmp, tmp, tmp2, tmp3); - dead_tmp(tmp3); - break; - case 6: /* VBIT */ - tmp3 = neon_load_reg(rd, pass); - gen_neon_bsl(tmp, tmp, tmp3, tmp2); - dead_tmp(tmp3); - break; - case 7: /* VBIF */ - tmp3 = neon_load_reg(rd, pass); - gen_neon_bsl(tmp, tmp3, tmp, tmp2); - dead_tmp(tmp3); - break; - } - break; - case 4: /* VHSUB */ - GEN_NEON_INTEGER_OP(hsub); - break; - case 5: /* VQSUB */ - GEN_NEON_INTEGER_OP_ENV(qsub); - break; - case 6: /* VCGT */ - GEN_NEON_INTEGER_OP(cgt); - break; - case 7: /* VCGE */ - GEN_NEON_INTEGER_OP(cge); - break; - case 8: /* VSHL */ - GEN_NEON_INTEGER_OP(shl); - break; - case 9: /* VQSHL */ - GEN_NEON_INTEGER_OP_ENV(qshl); - break; - case 10: /* VRSHL */ - GEN_NEON_INTEGER_OP(rshl); - break; - case 11: /* VQRSHL */ - GEN_NEON_INTEGER_OP_ENV(qrshl); - break; - case 12: /* VMAX */ - GEN_NEON_INTEGER_OP(max); - break; - case 13: /* VMIN */ - GEN_NEON_INTEGER_OP(min); - break; - case 14: /* VABD */ - GEN_NEON_INTEGER_OP(abd); - break; - case 15: /* VABA */ - GEN_NEON_INTEGER_OP(abd); - dead_tmp(tmp2); - tmp2 = neon_load_reg(rd, pass); - gen_neon_add(size, tmp, tmp2); - break; - case 16: - if (!u) { /* VADD */ - if (gen_neon_add(size, tmp, tmp2)) - return 1; - } else { /* VSUB */ - switch (size) { - case 0: gen_helper_neon_sub_u8(tmp, tmp, tmp2); break; - case 1: gen_helper_neon_sub_u16(tmp, tmp, tmp2); break; - case 2: tcg_gen_sub_i32(tmp, tmp, tmp2); break; - default: return 1; - } - } - break; - case 17: - if (!u) { /* VTST */ - switch (size) { - case 0: gen_helper_neon_tst_u8(tmp, tmp, tmp2); break; - case 1: gen_helper_neon_tst_u16(tmp, tmp, tmp2); break; - case 2: gen_helper_neon_tst_u32(tmp, tmp, tmp2); break; - default: return 1; - } - } else { /* VCEQ */ - switch (size) { - case 0: gen_helper_neon_ceq_u8(tmp, tmp, tmp2); break; - case 1: gen_helper_neon_ceq_u16(tmp, tmp, tmp2); break; - case 2: gen_helper_neon_ceq_u32(tmp, tmp, tmp2); break; - default: return 1; - } - } - break; - case 18: /* Multiply. */ - switch (size) { - case 0: gen_helper_neon_mul_u8(tmp, tmp, tmp2); break; - case 1: gen_helper_neon_mul_u16(tmp, tmp, tmp2); break; - case 2: tcg_gen_mul_i32(tmp, tmp, tmp2); break; - default: return 1; - } - dead_tmp(tmp2); - tmp2 = neon_load_reg(rd, pass); - if (u) { /* VMLS */ - gen_neon_rsb(size, tmp, tmp2); - } else { /* VMLA */ - gen_neon_add(size, tmp, tmp2); - } - break; - case 19: /* VMUL */ - if (u) { /* polynomial */ - gen_helper_neon_mul_p8(tmp, tmp, tmp2); - } else { /* Integer */ - switch (size) { - case 0: gen_helper_neon_mul_u8(tmp, tmp, tmp2); break; - case 1: gen_helper_neon_mul_u16(tmp, tmp, tmp2); break; - case 2: tcg_gen_mul_i32(tmp, tmp, tmp2); break; - default: return 1; - } - } - break; - case 20: /* VPMAX */ - GEN_NEON_INTEGER_OP(pmax); - break; - case 21: /* VPMIN */ - GEN_NEON_INTEGER_OP(pmin); - break; - case 22: /* Hultiply high. */ - if (!u) { /* VQDMULH */ - switch (size) { - case 1: gen_helper_neon_qdmulh_s16(tmp, cpu_env, tmp, tmp2); break; - case 2: gen_helper_neon_qdmulh_s32(tmp, cpu_env, tmp, tmp2); break; - default: return 1; - } - } else { /* VQRDHMUL */ - switch (size) { - case 1: gen_helper_neon_qrdmulh_s16(tmp, cpu_env, tmp, tmp2); break; - case 2: gen_helper_neon_qrdmulh_s32(tmp, cpu_env, tmp, tmp2); break; - default: return 1; - } - } - break; - case 23: /* VPADD */ - if (u) - return 1; - switch (size) { - case 0: gen_helper_neon_padd_u8(tmp, tmp, tmp2); break; - case 1: gen_helper_neon_padd_u16(tmp, tmp, tmp2); break; - case 2: tcg_gen_add_i32(tmp, tmp, tmp2); break; - default: return 1; - } - break; - case 26: /* Floating point arithnetic. */ - switch ((u << 2) | size) { - case 0: /* VADD */ - gen_helper_neon_add_f32(tmp, tmp, tmp2); - break; - case 2: /* VSUB */ - gen_helper_neon_sub_f32(tmp, tmp, tmp2); - break; - case 4: /* VPADD */ - gen_helper_neon_add_f32(tmp, tmp, tmp2); - break; - case 6: /* VABD */ - gen_helper_neon_abd_f32(tmp, tmp, tmp2); - break; - default: - return 1; - } - break; - case 27: /* Float multiply. */ - gen_helper_neon_mul_f32(tmp, tmp, tmp2); - if (!u) { - dead_tmp(tmp2); - tmp2 = neon_load_reg(rd, pass); - if (size == 0) { - gen_helper_neon_add_f32(tmp, tmp, tmp2); - } else { - gen_helper_neon_sub_f32(tmp, tmp2, tmp); - } - } - break; - case 28: /* Float compare. */ - if (!u) { - gen_helper_neon_ceq_f32(tmp, tmp, tmp2); - } else { - if (size == 0) - gen_helper_neon_cge_f32(tmp, tmp, tmp2); - else - gen_helper_neon_cgt_f32(tmp, tmp, tmp2); - } - break; - case 29: /* Float compare absolute. */ - if (!u) - return 1; - if (size == 0) - gen_helper_neon_acge_f32(tmp, tmp, tmp2); - else - gen_helper_neon_acgt_f32(tmp, tmp, tmp2); - break; - case 30: /* Float min/max. */ - if (size == 0) - gen_helper_neon_max_f32(tmp, tmp, tmp2); - else - gen_helper_neon_min_f32(tmp, tmp, tmp2); - break; - case 31: - if (size == 0) - gen_helper_recps_f32(tmp, tmp, tmp2, cpu_env); - else - gen_helper_rsqrts_f32(tmp, tmp, tmp2, cpu_env); - break; - default: - abort(); - } - dead_tmp(tmp2); - - /* Save the result. For elementwise operations we can put it - straight into the destination register. For pairwise operations - we have to be careful to avoid clobbering the source operands. */ - if (pairwise && rd == rm) { - neon_store_scratch(pass, tmp); - } else { - neon_store_reg(rd, pass, tmp); - } - - } /* for pass */ - if (pairwise && rd == rm) { - for (pass = 0; pass < (q ? 4 : 2); pass++) { - tmp = neon_load_scratch(pass); - neon_store_reg(rd, pass, tmp); - } - } - /* End of 3 register same size operations. */ - } else if (insn & (1 << 4)) { - if ((insn & 0x00380080) != 0) { - /* Two registers and shift. */ - op = (insn >> 8) & 0xf; - if (insn & (1 << 7)) { - /* 64-bit shift. */ - size = 3; - } else { - size = 2; - while ((insn & (1 << (size + 19))) == 0) - size--; - } - shift = (insn >> 16) & ((1 << (3 + size)) - 1); - /* To avoid excessive dumplication of ops we implement shift - by immediate using the variable shift operations. */ - if (op < 8) { - /* Shift by immediate: - VSHR, VSRA, VRSHR, VRSRA, VSRI, VSHL, VQSHL, VQSHLU. */ - /* Right shifts are encoded as N - shift, where N is the - element size in bits. */ - if (op <= 4) - shift = shift - (1 << (size + 3)); - if (size == 3) { - count = q + 1; - } else { - count = q ? 4: 2; - } - switch (size) { - case 0: - imm = (uint8_t) shift; - imm |= imm << 8; - imm |= imm << 16; - break; - case 1: - imm = (uint16_t) shift; - imm |= imm << 16; - break; - case 2: - case 3: - imm = shift; - break; - default: - abort(); - } - - for (pass = 0; pass < count; pass++) { - if (size == 3) { - neon_load_reg64(cpu_V0, rm + pass); - tcg_gen_movi_i64(cpu_V1, imm); - switch (op) { - case 0: /* VSHR */ - case 1: /* VSRA */ - if (u) - gen_helper_neon_shl_u64(cpu_V0, cpu_V0, cpu_V1); - else - gen_helper_neon_shl_s64(cpu_V0, cpu_V0, cpu_V1); - break; - case 2: /* VRSHR */ - case 3: /* VRSRA */ - if (u) - gen_helper_neon_rshl_u64(cpu_V0, cpu_V0, cpu_V1); - else - gen_helper_neon_rshl_s64(cpu_V0, cpu_V0, cpu_V1); - break; - case 4: /* VSRI */ - if (!u) - return 1; - gen_helper_neon_shl_u64(cpu_V0, cpu_V0, cpu_V1); - break; - case 5: /* VSHL, VSLI */ - gen_helper_neon_shl_u64(cpu_V0, cpu_V0, cpu_V1); - break; - case 6: /* VQSHL */ - if (u) - gen_helper_neon_qshl_u64(cpu_V0, cpu_env, cpu_V0, cpu_V1); - else - gen_helper_neon_qshl_s64(cpu_V0, cpu_env, cpu_V0, cpu_V1); - break; - case 7: /* VQSHLU */ - gen_helper_neon_qshl_u64(cpu_V0, cpu_env, cpu_V0, cpu_V1); - break; - } - if (op == 1 || op == 3) { - /* Accumulate. */ - neon_load_reg64(cpu_V0, rd + pass); - tcg_gen_add_i64(cpu_V0, cpu_V0, cpu_V1); - } else if (op == 4 || (op == 5 && u)) { - /* Insert */ - cpu_abort(env, "VS[LR]I.64 not implemented"); - } - neon_store_reg64(cpu_V0, rd + pass); - } else { /* size < 3 */ - /* Operands in T0 and T1. */ - tmp = neon_load_reg(rm, pass); - tmp2 = new_tmp(); - tcg_gen_movi_i32(tmp2, imm); - switch (op) { - case 0: /* VSHR */ - case 1: /* VSRA */ - GEN_NEON_INTEGER_OP(shl); - break; - case 2: /* VRSHR */ - case 3: /* VRSRA */ - GEN_NEON_INTEGER_OP(rshl); - break; - case 4: /* VSRI */ - if (!u) - return 1; - GEN_NEON_INTEGER_OP(shl); - break; - case 5: /* VSHL, VSLI */ - switch (size) { - case 0: gen_helper_neon_shl_u8(tmp, tmp, tmp2); break; - case 1: gen_helper_neon_shl_u16(tmp, tmp, tmp2); break; - case 2: gen_helper_neon_shl_u32(tmp, tmp, tmp2); break; - default: return 1; - } - break; - case 6: /* VQSHL */ - GEN_NEON_INTEGER_OP_ENV(qshl); - break; - case 7: /* VQSHLU */ - switch (size) { - case 0: gen_helper_neon_qshl_u8(tmp, cpu_env, tmp, tmp2); break; - case 1: gen_helper_neon_qshl_u16(tmp, cpu_env, tmp, tmp2); break; - case 2: gen_helper_neon_qshl_u32(tmp, cpu_env, tmp, tmp2); break; - default: return 1; - } - break; - } - dead_tmp(tmp2); - - if (op == 1 || op == 3) { - /* Accumulate. */ - tmp2 = neon_load_reg(rd, pass); - gen_neon_add(size, tmp2, tmp); - dead_tmp(tmp2); - } else if (op == 4 || (op == 5 && u)) { - /* Insert */ - switch (size) { - case 0: - if (op == 4) - mask = 0xff >> -shift; - else - mask = (uint8_t)(0xff << shift); - mask |= mask << 8; - mask |= mask << 16; - break; - case 1: - if (op == 4) - mask = 0xffff >> -shift; - else - mask = (uint16_t)(0xffff << shift); - mask |= mask << 16; - break; - case 2: - if (shift < -31 || shift > 31) { - mask = 0; - } else { - if (op == 4) - mask = 0xffffffffu >> -shift; - else - mask = 0xffffffffu << shift; - } - break; - default: - abort(); - } - tmp2 = neon_load_reg(rd, pass); - tcg_gen_andi_i32(tmp, tmp, mask); - tcg_gen_andi_i32(tmp2, tmp2, ~mask); - tcg_gen_or_i32(tmp, tmp, tmp2); - dead_tmp(tmp2); - } - neon_store_reg(rd, pass, tmp); - } - } /* for pass */ - } else if (op < 10) { - /* Shift by immediate and narrow: - VSHRN, VRSHRN, VQSHRN, VQRSHRN. */ - shift = shift - (1 << (size + 3)); - size++; - switch (size) { - case 1: - imm = (uint16_t)shift; - imm |= imm << 16; - tmp2 = tcg_const_i32(imm); - TCGV_UNUSED_I64(tmp64); - break; - case 2: - imm = (uint32_t)shift; - tmp2 = tcg_const_i32(imm); - TCGV_UNUSED_I64(tmp64); - break; - case 3: - tmp64 = tcg_const_i64(shift); - TCGV_UNUSED(tmp2); - break; - default: - abort(); - } - - for (pass = 0; pass < 2; pass++) { - if (size == 3) { - neon_load_reg64(cpu_V0, rm + pass); - if (q) { - if (u) - gen_helper_neon_rshl_u64(cpu_V0, cpu_V0, tmp64); - else - gen_helper_neon_rshl_s64(cpu_V0, cpu_V0, tmp64); - } else { - if (u) - gen_helper_neon_shl_u64(cpu_V0, cpu_V0, tmp64); - else - gen_helper_neon_shl_s64(cpu_V0, cpu_V0, tmp64); - } - } else { - tmp = neon_load_reg(rm + pass, 0); - gen_neon_shift_narrow(size, tmp, tmp2, q, u); - tmp3 = neon_load_reg(rm + pass, 1); - gen_neon_shift_narrow(size, tmp3, tmp2, q, u); - tcg_gen_concat_i32_i64(cpu_V0, tmp, tmp3); - dead_tmp(tmp); - dead_tmp(tmp3); - } - tmp = new_tmp(); - if (op == 8 && !u) { - gen_neon_narrow(size - 1, tmp, cpu_V0); - } else { - if (op == 8) - gen_neon_narrow_sats(size - 1, tmp, cpu_V0); - else - gen_neon_narrow_satu(size - 1, tmp, cpu_V0); - } - neon_store_reg(rd, pass, tmp); - } /* for pass */ - if (size == 3) { - tcg_temp_free_i64(tmp64); - } else { - dead_tmp(tmp2); - } - } else if (op == 10) { - /* VSHLL */ - if (q || size == 3) - return 1; - tmp = neon_load_reg(rm, 0); - tmp2 = neon_load_reg(rm, 1); - for (pass = 0; pass < 2; pass++) { - if (pass == 1) - tmp = tmp2; - - gen_neon_widen(cpu_V0, tmp, size, u); - - if (shift != 0) { - /* The shift is less than the width of the source - type, so we can just shift the whole register. */ - tcg_gen_shli_i64(cpu_V0, cpu_V0, shift); - if (size < 2 || !u) { - uint64_t imm64; - if (size == 0) { - imm = (0xffu >> (8 - shift)); - imm |= imm << 16; - } else { - imm = 0xffff >> (16 - shift); - } - imm64 = imm | (((uint64_t)imm) << 32); - tcg_gen_andi_i64(cpu_V0, cpu_V0, imm64); - } - } - neon_store_reg64(cpu_V0, rd + pass); - } - } else if (op == 15 || op == 16) { - /* VCVT fixed-point. */ - for (pass = 0; pass < (q ? 4 : 2); pass++) { - tcg_gen_ld_f32(cpu_F0s, cpu_env, neon_reg_offset(rm, pass)); - if (op & 1) { - if (u) - gen_vfp_ulto(0, shift); - else - gen_vfp_slto(0, shift); - } else { - if (u) - gen_vfp_toul(0, shift); - else - gen_vfp_tosl(0, shift); - } - tcg_gen_st_f32(cpu_F0s, cpu_env, neon_reg_offset(rd, pass)); - } - } else { - return 1; - } - } else { /* (insn & 0x00380080) == 0 */ - int invert; - - op = (insn >> 8) & 0xf; - /* One register and immediate. */ - imm = (u << 7) | ((insn >> 12) & 0x70) | (insn & 0xf); - invert = (insn & (1 << 5)) != 0; - switch (op) { - case 0: case 1: - /* no-op */ - break; - case 2: case 3: - imm <<= 8; - break; - case 4: case 5: - imm <<= 16; - break; - case 6: case 7: - imm <<= 24; - break; - case 8: case 9: - imm |= imm << 16; - break; - case 10: case 11: - imm = (imm << 8) | (imm << 24); - break; - case 12: - imm = (imm < 8) | 0xff; - break; - case 13: - imm = (imm << 16) | 0xffff; - break; - case 14: - imm |= (imm << 8) | (imm << 16) | (imm << 24); - if (invert) - imm = ~imm; - break; - case 15: - imm = ((imm & 0x80) << 24) | ((imm & 0x3f) << 19) - | ((imm & 0x40) ? (0x1f << 25) : (1 << 30)); - break; - } - if (invert) - imm = ~imm; - - for (pass = 0; pass < (q ? 4 : 2); pass++) { - if (op & 1 && op < 12) { - tmp = neon_load_reg(rd, pass); - if (invert) { - /* The immediate value has already been inverted, so - BIC becomes AND. */ - tcg_gen_andi_i32(tmp, tmp, imm); - } else { - tcg_gen_ori_i32(tmp, tmp, imm); - } - } else { - /* VMOV, VMVN. */ - tmp = new_tmp(); - if (op == 14 && invert) { - uint32_t val; - val = 0; - for (n = 0; n < 4; n++) { - if (imm & (1 << (n + (pass & 1) * 4))) - val |= 0xff << (n * 8); - } - tcg_gen_movi_i32(tmp, val); - } else { - tcg_gen_movi_i32(tmp, imm); - } - } - neon_store_reg(rd, pass, tmp); - } - } - } else { /* (insn & 0x00800010 == 0x00800000) */ - if (size != 3) { - op = (insn >> 8) & 0xf; - if ((insn & (1 << 6)) == 0) { - /* Three registers of different lengths. */ - int src1_wide; - int src2_wide; - int prewiden; - /* prewiden, src1_wide, src2_wide */ - static const int neon_3reg_wide[16][3] = { - {1, 0, 0}, /* VADDL */ - {1, 1, 0}, /* VADDW */ - {1, 0, 0}, /* VSUBL */ - {1, 1, 0}, /* VSUBW */ - {0, 1, 1}, /* VADDHN */ - {0, 0, 0}, /* VABAL */ - {0, 1, 1}, /* VSUBHN */ - {0, 0, 0}, /* VABDL */ - {0, 0, 0}, /* VMLAL */ - {0, 0, 0}, /* VQDMLAL */ - {0, 0, 0}, /* VMLSL */ - {0, 0, 0}, /* VQDMLSL */ - {0, 0, 0}, /* Integer VMULL */ - {0, 0, 0}, /* VQDMULL */ - {0, 0, 0} /* Polynomial VMULL */ - }; - - prewiden = neon_3reg_wide[op][0]; - src1_wide = neon_3reg_wide[op][1]; - src2_wide = neon_3reg_wide[op][2]; - - if (size == 0 && (op == 9 || op == 11 || op == 13)) - return 1; - - /* Avoid overlapping operands. Wide source operands are - always aligned so will never overlap with wide - destinations in problematic ways. */ - if (rd == rm && !src2_wide) { - tmp = neon_load_reg(rm, 1); - neon_store_scratch(2, tmp); - } else if (rd == rn && !src1_wide) { - tmp = neon_load_reg(rn, 1); - neon_store_scratch(2, tmp); - } - TCGV_UNUSED(tmp3); - for (pass = 0; pass < 2; pass++) { - if (src1_wide) { - neon_load_reg64(cpu_V0, rn + pass); - TCGV_UNUSED(tmp); - } else { - if (pass == 1 && rd == rn) { - tmp = neon_load_scratch(2); - } else { - tmp = neon_load_reg(rn, pass); - } - if (prewiden) { - gen_neon_widen(cpu_V0, tmp, size, u); - } - } - if (src2_wide) { - neon_load_reg64(cpu_V1, rm + pass); - TCGV_UNUSED(tmp2); - } else { - if (pass == 1 && rd == rm) { - tmp2 = neon_load_scratch(2); - } else { - tmp2 = neon_load_reg(rm, pass); - } - if (prewiden) { - gen_neon_widen(cpu_V1, tmp2, size, u); - } - } - switch (op) { - case 0: case 1: case 4: /* VADDL, VADDW, VADDHN, VRADDHN */ - gen_neon_addl(size); - break; - case 2: case 3: case 6: /* VSUBL, VSUBW, VSUBHL, VRSUBHL */ - gen_neon_subl(size); - break; - case 5: case 7: /* VABAL, VABDL */ - switch ((size << 1) | u) { - case 0: - gen_helper_neon_abdl_s16(cpu_V0, tmp, tmp2); - break; - case 1: - gen_helper_neon_abdl_u16(cpu_V0, tmp, tmp2); - break; - case 2: - gen_helper_neon_abdl_s32(cpu_V0, tmp, tmp2); - break; - case 3: - gen_helper_neon_abdl_u32(cpu_V0, tmp, tmp2); - break; - case 4: - gen_helper_neon_abdl_s64(cpu_V0, tmp, tmp2); - break; - case 5: - gen_helper_neon_abdl_u64(cpu_V0, tmp, tmp2); - break; - default: abort(); - } - dead_tmp(tmp2); - dead_tmp(tmp); - break; - case 8: case 9: case 10: case 11: case 12: case 13: - /* VMLAL, VQDMLAL, VMLSL, VQDMLSL, VMULL, VQDMULL */ - gen_neon_mull(cpu_V0, tmp, tmp2, size, u); - dead_tmp(tmp2); - dead_tmp(tmp); - break; - case 14: /* Polynomial VMULL */ - cpu_abort(env, "Polynomial VMULL not implemented"); - - default: /* 15 is RESERVED. */ - return 1; - } - if (op == 5 || op == 13 || (op >= 8 && op <= 11)) { - /* Accumulate. */ - if (op == 10 || op == 11) { - gen_neon_negl(cpu_V0, size); - } - - if (op != 13) { - neon_load_reg64(cpu_V1, rd + pass); - } - - switch (op) { - case 5: case 8: case 10: /* VABAL, VMLAL, VMLSL */ - gen_neon_addl(size); - break; - case 9: case 11: /* VQDMLAL, VQDMLSL */ - gen_neon_addl_saturate(cpu_V0, cpu_V0, size); - gen_neon_addl_saturate(cpu_V0, cpu_V1, size); - break; - /* Fall through. */ - case 13: /* VQDMULL */ - gen_neon_addl_saturate(cpu_V0, cpu_V0, size); - break; - default: - abort(); - } - neon_store_reg64(cpu_V0, rd + pass); - } else if (op == 4 || op == 6) { - /* Narrowing operation. */ - tmp = new_tmp(); - if (u) { - switch (size) { - case 0: - gen_helper_neon_narrow_high_u8(tmp, cpu_V0); - break; - case 1: - gen_helper_neon_narrow_high_u16(tmp, cpu_V0); - break; - case 2: - tcg_gen_shri_i64(cpu_V0, cpu_V0, 32); - tcg_gen_trunc_i64_i32(tmp, cpu_V0); - break; - default: abort(); - } - } else { - switch (size) { - case 0: - gen_helper_neon_narrow_round_high_u8(tmp, cpu_V0); - break; - case 1: - gen_helper_neon_narrow_round_high_u16(tmp, cpu_V0); - break; - case 2: - tcg_gen_addi_i64(cpu_V0, cpu_V0, 1u << 31); - tcg_gen_shri_i64(cpu_V0, cpu_V0, 32); - tcg_gen_trunc_i64_i32(tmp, cpu_V0); - break; - default: abort(); - } - } - if (pass == 0) { - tmp3 = tmp; - } else { - neon_store_reg(rd, 0, tmp3); - neon_store_reg(rd, 1, tmp); - } - } else { - /* Write back the result. */ - neon_store_reg64(cpu_V0, rd + pass); - } - } - } else { - /* Two registers and a scalar. */ - switch (op) { - case 0: /* Integer VMLA scalar */ - case 1: /* Float VMLA scalar */ - case 4: /* Integer VMLS scalar */ - case 5: /* Floating point VMLS scalar */ - case 8: /* Integer VMUL scalar */ - case 9: /* Floating point VMUL scalar */ - case 12: /* VQDMULH scalar */ - case 13: /* VQRDMULH scalar */ - tmp = neon_get_scalar(size, rm); - neon_store_scratch(0, tmp); - for (pass = 0; pass < (u ? 4 : 2); pass++) { - tmp = neon_load_scratch(0); - tmp2 = neon_load_reg(rn, pass); - if (op == 12) { - if (size == 1) { - gen_helper_neon_qdmulh_s16(tmp, cpu_env, tmp, tmp2); - } else { - gen_helper_neon_qdmulh_s32(tmp, cpu_env, tmp, tmp2); - } - } else if (op == 13) { - if (size == 1) { - gen_helper_neon_qrdmulh_s16(tmp, cpu_env, tmp, tmp2); - } else { - gen_helper_neon_qrdmulh_s32(tmp, cpu_env, tmp, tmp2); - } - } else if (op & 1) { - gen_helper_neon_mul_f32(tmp, tmp, tmp2); - } else { - switch (size) { - case 0: gen_helper_neon_mul_u8(tmp, tmp, tmp2); break; - case 1: gen_helper_neon_mul_u16(tmp, tmp, tmp2); break; - case 2: tcg_gen_mul_i32(tmp, tmp, tmp2); break; - default: return 1; - } - } - dead_tmp(tmp2); - if (op < 8) { - /* Accumulate. */ - tmp2 = neon_load_reg(rd, pass); - switch (op) { - case 0: - gen_neon_add(size, tmp, tmp2); - break; - case 1: - gen_helper_neon_add_f32(tmp, tmp, tmp2); - break; - case 4: - gen_neon_rsb(size, tmp, tmp2); - break; - case 5: - gen_helper_neon_sub_f32(tmp, tmp2, tmp); - break; - default: - abort(); - } - dead_tmp(tmp2); - } - neon_store_reg(rd, pass, tmp); - } - break; - case 2: /* VMLAL sclar */ - case 3: /* VQDMLAL scalar */ - case 6: /* VMLSL scalar */ - case 7: /* VQDMLSL scalar */ - case 10: /* VMULL scalar */ - case 11: /* VQDMULL scalar */ - if (size == 0 && (op == 3 || op == 7 || op == 11)) - return 1; - - tmp2 = neon_get_scalar(size, rm); - tmp3 = neon_load_reg(rn, 1); - - for (pass = 0; pass < 2; pass++) { - if (pass == 0) { - tmp = neon_load_reg(rn, 0); - } else { - tmp = tmp3; - } - gen_neon_mull(cpu_V0, tmp, tmp2, size, u); - dead_tmp(tmp); - if (op == 6 || op == 7) { - gen_neon_negl(cpu_V0, size); - } - if (op != 11) { - neon_load_reg64(cpu_V1, rd + pass); - } - switch (op) { - case 2: case 6: - gen_neon_addl(size); - break; - case 3: case 7: - gen_neon_addl_saturate(cpu_V0, cpu_V0, size); - gen_neon_addl_saturate(cpu_V0, cpu_V1, size); - break; - case 10: - /* no-op */ - break; - case 11: - gen_neon_addl_saturate(cpu_V0, cpu_V0, size); - break; - default: - abort(); - } - neon_store_reg64(cpu_V0, rd + pass); - } - - dead_tmp(tmp2); - - break; - default: /* 14 and 15 are RESERVED */ - return 1; - } - } - } else { /* size == 3 */ - if (!u) { - /* Extract. */ - imm = (insn >> 8) & 0xf; - count = q + 1; - - if (imm > 7 && !q) - return 1; - - if (imm == 0) { - neon_load_reg64(cpu_V0, rn); - if (q) { - neon_load_reg64(cpu_V1, rn + 1); - } - } else if (imm == 8) { - neon_load_reg64(cpu_V0, rn + 1); - if (q) { - neon_load_reg64(cpu_V1, rm); - } - } else if (q) { - tmp64 = tcg_temp_new_i64(); - if (imm < 8) { - neon_load_reg64(cpu_V0, rn); - neon_load_reg64(tmp64, rn + 1); - } else { - neon_load_reg64(cpu_V0, rn + 1); - neon_load_reg64(tmp64, rm); - } - tcg_gen_shri_i64(cpu_V0, cpu_V0, (imm & 7) * 8); - tcg_gen_shli_i64(cpu_V1, tmp64, 64 - ((imm & 7) * 8)); - tcg_gen_or_i64(cpu_V0, cpu_V0, cpu_V1); - if (imm < 8) { - neon_load_reg64(cpu_V1, rm); - } else { - neon_load_reg64(cpu_V1, rm + 1); - imm -= 8; - } - tcg_gen_shli_i64(cpu_V1, cpu_V1, 64 - (imm * 8)); - tcg_gen_shri_i64(tmp64, tmp64, imm * 8); - tcg_gen_or_i64(cpu_V1, cpu_V1, tmp64); - tcg_temp_free_i64(tmp64); - } else { - /* BUGFIX */ - neon_load_reg64(cpu_V0, rn); - tcg_gen_shri_i64(cpu_V0, cpu_V0, imm * 8); - neon_load_reg64(cpu_V1, rm); - tcg_gen_shli_i64(cpu_V1, cpu_V1, 64 - (imm * 8)); - tcg_gen_or_i64(cpu_V0, cpu_V0, cpu_V1); - } - neon_store_reg64(cpu_V0, rd); - if (q) { - neon_store_reg64(cpu_V1, rd + 1); - } - } else if ((insn & (1 << 11)) == 0) { - /* Two register misc. */ - op = ((insn >> 12) & 0x30) | ((insn >> 7) & 0xf); - size = (insn >> 18) & 3; - switch (op) { - case 0: /* VREV64 */ - if (size == 3) - return 1; - for (pass = 0; pass < (q ? 2 : 1); pass++) { - tmp = neon_load_reg(rm, pass * 2); - tmp2 = neon_load_reg(rm, pass * 2 + 1); - switch (size) { - case 0: tcg_gen_bswap32_i32(tmp, tmp); break; - case 1: gen_swap_half(tmp); break; - case 2: /* no-op */ break; - default: abort(); - } - neon_store_reg(rd, pass * 2 + 1, tmp); - if (size == 2) { - neon_store_reg(rd, pass * 2, tmp2); - } else { - switch (size) { - case 0: tcg_gen_bswap32_i32(tmp2, tmp2); break; - case 1: gen_swap_half(tmp2); break; - default: abort(); - } - neon_store_reg(rd, pass * 2, tmp2); - } - } - break; - case 4: case 5: /* VPADDL */ - case 12: case 13: /* VPADAL */ - if (size == 3) - return 1; - for (pass = 0; pass < q + 1; pass++) { - tmp = neon_load_reg(rm, pass * 2); - gen_neon_widen(cpu_V0, tmp, size, op & 1); - tmp = neon_load_reg(rm, pass * 2 + 1); - gen_neon_widen(cpu_V1, tmp, size, op & 1); - switch (size) { - case 0: gen_helper_neon_paddl_u16(CPU_V001); break; - case 1: gen_helper_neon_paddl_u32(CPU_V001); break; - case 2: tcg_gen_add_i64(CPU_V001); break; - default: abort(); - } - if (op >= 12) { - /* Accumulate. */ - neon_load_reg64(cpu_V1, rd + pass); - gen_neon_addl(size); - } - neon_store_reg64(cpu_V0, rd + pass); - } - break; - case 33: /* VTRN */ - if (size == 2) { - for (n = 0; n < (q ? 4 : 2); n += 2) { - tmp = neon_load_reg(rm, n); - tmp2 = neon_load_reg(rd, n + 1); - neon_store_reg(rm, n, tmp2); - neon_store_reg(rd, n + 1, tmp); - } - } else { - goto elementwise; - } - break; - case 34: /* VUZP */ - /* Reg Before After - Rd A3 A2 A1 A0 B2 B0 A2 A0 - Rm B3 B2 B1 B0 B3 B1 A3 A1 - */ - if (size == 3) - return 1; - gen_neon_unzip(rd, q, 0, size); - gen_neon_unzip(rm, q, 4, size); - if (q) { - static int unzip_order_q[8] = - {0, 2, 4, 6, 1, 3, 5, 7}; - for (n = 0; n < 8; n++) { - int reg = (n < 4) ? rd : rm; - tmp = neon_load_scratch(unzip_order_q[n]); - neon_store_reg(reg, n % 4, tmp); - } - } else { - static int unzip_order[4] = - {0, 4, 1, 5}; - for (n = 0; n < 4; n++) { - int reg = (n < 2) ? rd : rm; - tmp = neon_load_scratch(unzip_order[n]); - neon_store_reg(reg, n % 2, tmp); - } - } - break; - case 35: /* VZIP */ - /* Reg Before After - Rd A3 A2 A1 A0 B1 A1 B0 A0 - Rm B3 B2 B1 B0 B3 A3 B2 A2 - */ - if (size == 3) - return 1; - count = (q ? 4 : 2); - for (n = 0; n < count; n++) { - tmp = neon_load_reg(rd, n); - tmp2 = neon_load_reg(rd, n); - switch (size) { - case 0: gen_neon_zip_u8(tmp, tmp2); break; - case 1: gen_neon_zip_u16(tmp, tmp2); break; - case 2: /* no-op */; break; - default: abort(); - } - neon_store_scratch(n * 2, tmp); - neon_store_scratch(n * 2 + 1, tmp2); - } - for (n = 0; n < count * 2; n++) { - int reg = (n < count) ? rd : rm; - tmp = neon_load_scratch(n); - neon_store_reg(reg, n % count, tmp); - } - break; - case 36: case 37: /* VMOVN, VQMOVUN, VQMOVN */ - if (size == 3) - return 1; - TCGV_UNUSED(tmp2); - for (pass = 0; pass < 2; pass++) { - neon_load_reg64(cpu_V0, rm + pass); - tmp = new_tmp(); - if (op == 36 && q == 0) { - gen_neon_narrow(size, tmp, cpu_V0); - } else if (q) { - gen_neon_narrow_satu(size, tmp, cpu_V0); - } else { - gen_neon_narrow_sats(size, tmp, cpu_V0); - } - if (pass == 0) { - tmp2 = tmp; - } else { - neon_store_reg(rd, 0, tmp2); - neon_store_reg(rd, 1, tmp); - } - } - break; - case 38: /* VSHLL */ - if (q || size == 3) - return 1; - tmp = neon_load_reg(rm, 0); - tmp2 = neon_load_reg(rm, 1); - for (pass = 0; pass < 2; pass++) { - if (pass == 1) - tmp = tmp2; - gen_neon_widen(cpu_V0, tmp, size, 1); - neon_store_reg64(cpu_V0, rd + pass); - } - break; - case 44: /* VCVT.F16.F32 */ - if (!arm_feature(env, ARM_FEATURE_VFP_FP16)) - return 1; - tmp = new_tmp(); - tmp2 = new_tmp(); - tcg_gen_ld_f32(cpu_F0s, cpu_env, neon_reg_offset(rm, 0)); - gen_helper_vfp_fcvt_f32_to_f16(tmp, cpu_F0s, cpu_env); - tcg_gen_ld_f32(cpu_F0s, cpu_env, neon_reg_offset(rm, 1)); - gen_helper_vfp_fcvt_f32_to_f16(tmp2, cpu_F0s, cpu_env); - tcg_gen_shli_i32(tmp2, tmp2, 16); - tcg_gen_or_i32(tmp2, tmp2, tmp); - tcg_gen_ld_f32(cpu_F0s, cpu_env, neon_reg_offset(rm, 2)); - gen_helper_vfp_fcvt_f32_to_f16(tmp, cpu_F0s, cpu_env); - tcg_gen_ld_f32(cpu_F0s, cpu_env, neon_reg_offset(rm, 3)); - neon_store_reg(rd, 0, tmp2); - tmp2 = new_tmp(); - gen_helper_vfp_fcvt_f32_to_f16(tmp2, cpu_F0s, cpu_env); - tcg_gen_shli_i32(tmp2, tmp2, 16); - tcg_gen_or_i32(tmp2, tmp2, tmp); - neon_store_reg(rd, 1, tmp2); - dead_tmp(tmp); - break; - case 46: /* VCVT.F32.F16 */ - if (!arm_feature(env, ARM_FEATURE_VFP_FP16)) - return 1; - tmp3 = new_tmp(); - tmp = neon_load_reg(rm, 0); - tmp2 = neon_load_reg(rm, 1); - tcg_gen_ext16u_i32(tmp3, tmp); - gen_helper_vfp_fcvt_f16_to_f32(cpu_F0s, tmp3, cpu_env); - tcg_gen_st_f32(cpu_F0s, cpu_env, neon_reg_offset(rd, 0)); - tcg_gen_shri_i32(tmp3, tmp, 16); - gen_helper_vfp_fcvt_f16_to_f32(cpu_F0s, tmp3, cpu_env); - tcg_gen_st_f32(cpu_F0s, cpu_env, neon_reg_offset(rd, 1)); - dead_tmp(tmp); - tcg_gen_ext16u_i32(tmp3, tmp2); - gen_helper_vfp_fcvt_f16_to_f32(cpu_F0s, tmp3, cpu_env); - tcg_gen_st_f32(cpu_F0s, cpu_env, neon_reg_offset(rd, 2)); - tcg_gen_shri_i32(tmp3, tmp2, 16); - gen_helper_vfp_fcvt_f16_to_f32(cpu_F0s, tmp3, cpu_env); - tcg_gen_st_f32(cpu_F0s, cpu_env, neon_reg_offset(rd, 3)); - dead_tmp(tmp2); - dead_tmp(tmp3); - break; - default: - elementwise: - for (pass = 0; pass < (q ? 4 : 2); pass++) { - if (op == 30 || op == 31 || op >= 58) { - tcg_gen_ld_f32(cpu_F0s, cpu_env, - neon_reg_offset(rm, pass)); - TCGV_UNUSED(tmp); - } else { - tmp = neon_load_reg(rm, pass); - } - switch (op) { - case 1: /* VREV32 */ - switch (size) { - case 0: tcg_gen_bswap32_i32(tmp, tmp); break; - case 1: gen_swap_half(tmp); break; - default: return 1; - } - break; - case 2: /* VREV16 */ - if (size != 0) - return 1; - gen_rev16(tmp); - break; - case 8: /* CLS */ - switch (size) { - case 0: gen_helper_neon_cls_s8(tmp, tmp); break; - case 1: gen_helper_neon_cls_s16(tmp, tmp); break; - case 2: gen_helper_neon_cls_s32(tmp, tmp); break; - default: return 1; - } - break; - case 9: /* CLZ */ - switch (size) { - case 0: gen_helper_neon_clz_u8(tmp, tmp); break; - case 1: gen_helper_neon_clz_u16(tmp, tmp); break; - case 2: gen_helper_clz(tmp, tmp); break; - default: return 1; - } - break; - case 10: /* CNT */ - if (size != 0) - return 1; - gen_helper_neon_cnt_u8(tmp, tmp); - break; - case 11: /* VNOT */ - if (size != 0) - return 1; - tcg_gen_not_i32(tmp, tmp); - break; - case 14: /* VQABS */ - switch (size) { - case 0: gen_helper_neon_qabs_s8(tmp, cpu_env, tmp); break; - case 1: gen_helper_neon_qabs_s16(tmp, cpu_env, tmp); break; - case 2: gen_helper_neon_qabs_s32(tmp, cpu_env, tmp); break; - default: return 1; - } - break; - case 15: /* VQNEG */ - switch (size) { - case 0: gen_helper_neon_qneg_s8(tmp, cpu_env, tmp); break; - case 1: gen_helper_neon_qneg_s16(tmp, cpu_env, tmp); break; - case 2: gen_helper_neon_qneg_s32(tmp, cpu_env, tmp); break; - default: return 1; - } - break; - case 16: case 19: /* VCGT #0, VCLE #0 */ - tmp2 = tcg_const_i32(0); - switch(size) { - case 0: gen_helper_neon_cgt_s8(tmp, tmp, tmp2); break; - case 1: gen_helper_neon_cgt_s16(tmp, tmp, tmp2); break; - case 2: gen_helper_neon_cgt_s32(tmp, tmp, tmp2); break; - default: return 1; - } - tcg_temp_free(tmp2); - if (op == 19) - tcg_gen_not_i32(tmp, tmp); - break; - case 17: case 20: /* VCGE #0, VCLT #0 */ - tmp2 = tcg_const_i32(0); - switch(size) { - case 0: gen_helper_neon_cge_s8(tmp, tmp, tmp2); break; - case 1: gen_helper_neon_cge_s16(tmp, tmp, tmp2); break; - case 2: gen_helper_neon_cge_s32(tmp, tmp, tmp2); break; - default: return 1; - } - tcg_temp_free(tmp2); - if (op == 20) - tcg_gen_not_i32(tmp, tmp); - break; - case 18: /* VCEQ #0 */ - tmp2 = tcg_const_i32(0); - switch(size) { - case 0: gen_helper_neon_ceq_u8(tmp, tmp, tmp2); break; - case 1: gen_helper_neon_ceq_u16(tmp, tmp, tmp2); break; - case 2: gen_helper_neon_ceq_u32(tmp, tmp, tmp2); break; - default: return 1; - } - tcg_temp_free(tmp2); - break; - case 22: /* VABS */ - switch(size) { - case 0: gen_helper_neon_abs_s8(tmp, tmp); break; - case 1: gen_helper_neon_abs_s16(tmp, tmp); break; - case 2: tcg_gen_abs_i32(tmp, tmp); break; - default: return 1; - } - break; - case 23: /* VNEG */ - if (size == 3) - return 1; - tmp2 = tcg_const_i32(0); - gen_neon_rsb(size, tmp, tmp2); - tcg_temp_free(tmp2); - break; - case 24: case 27: /* Float VCGT #0, Float VCLE #0 */ - tmp2 = tcg_const_i32(0); - gen_helper_neon_cgt_f32(tmp, tmp, tmp2); - tcg_temp_free(tmp2); - if (op == 27) - tcg_gen_not_i32(tmp, tmp); - break; - case 25: case 28: /* Float VCGE #0, Float VCLT #0 */ - tmp2 = tcg_const_i32(0); - gen_helper_neon_cge_f32(tmp, tmp, tmp2); - tcg_temp_free(tmp2); - if (op == 28) - tcg_gen_not_i32(tmp, tmp); - break; - case 26: /* Float VCEQ #0 */ - tmp2 = tcg_const_i32(0); - gen_helper_neon_ceq_f32(tmp, tmp, tmp2); - tcg_temp_free(tmp2); - break; - case 30: /* Float VABS */ - gen_vfp_abs(0); - break; - case 31: /* Float VNEG */ - gen_vfp_neg(0); - break; - case 32: /* VSWP */ - tmp2 = neon_load_reg(rd, pass); - neon_store_reg(rm, pass, tmp2); - break; - case 33: /* VTRN */ - tmp2 = neon_load_reg(rd, pass); - switch (size) { - case 0: gen_neon_trn_u8(tmp, tmp2); break; - case 1: gen_neon_trn_u16(tmp, tmp2); break; - case 2: abort(); - default: return 1; - } - neon_store_reg(rm, pass, tmp2); - break; - case 56: /* Integer VRECPE */ - gen_helper_recpe_u32(tmp, tmp, cpu_env); - break; - case 57: /* Integer VRSQRTE */ - gen_helper_rsqrte_u32(tmp, tmp, cpu_env); - break; - case 58: /* Float VRECPE */ - gen_helper_recpe_f32(cpu_F0s, cpu_F0s, cpu_env); - break; - case 59: /* Float VRSQRTE */ - gen_helper_rsqrte_f32(cpu_F0s, cpu_F0s, cpu_env); - break; - case 60: /* VCVT.F32.S32 */ - gen_vfp_tosiz(0); - break; - case 61: /* VCVT.F32.U32 */ - gen_vfp_touiz(0); - break; - case 62: /* VCVT.S32.F32 */ - gen_vfp_sito(0); - break; - case 63: /* VCVT.U32.F32 */ - gen_vfp_uito(0); - break; - default: - /* Reserved: 21, 29, 39-56 */ - return 1; - } - if (op == 30 || op == 31 || op >= 58) { - tcg_gen_st_f32(cpu_F0s, cpu_env, - neon_reg_offset(rd, pass)); - } else { - neon_store_reg(rd, pass, tmp); - } - } - break; - } - } else if ((insn & (1 << 10)) == 0) { - /* VTBL, VTBX. */ - n = ((insn >> 5) & 0x18) + 8; - if (insn & (1 << 6)) { - tmp = neon_load_reg(rd, 0); - } else { - tmp = new_tmp(); - tcg_gen_movi_i32(tmp, 0); - } - tmp2 = neon_load_reg(rm, 0); - tmp4 = tcg_const_i32(rn); - tmp5 = tcg_const_i32(n); - gen_helper_neon_tbl(tmp2, tmp2, tmp, tmp4, tmp5); - dead_tmp(tmp); - if (insn & (1 << 6)) { - tmp = neon_load_reg(rd, 1); - } else { - tmp = new_tmp(); - tcg_gen_movi_i32(tmp, 0); - } - tmp3 = neon_load_reg(rm, 1); - gen_helper_neon_tbl(tmp3, tmp3, tmp, tmp4, tmp5); - tcg_temp_free_i32(tmp5); - tcg_temp_free_i32(tmp4); - neon_store_reg(rd, 0, tmp2); - neon_store_reg(rd, 1, tmp3); - dead_tmp(tmp); - } else if ((insn & 0x380) == 0) { - /* VDUP */ - if (insn & (1 << 19)) { - tmp = neon_load_reg(rm, 1); - } else { - tmp = neon_load_reg(rm, 0); - } - if (insn & (1 << 16)) { - gen_neon_dup_u8(tmp, ((insn >> 17) & 3) * 8); - } else if (insn & (1 << 17)) { - if ((insn >> 18) & 1) - gen_neon_dup_high16(tmp); - else - gen_neon_dup_low16(tmp); - } - for (pass = 0; pass < (q ? 4 : 2); pass++) { - tmp2 = new_tmp(); - tcg_gen_mov_i32(tmp2, tmp); - neon_store_reg(rd, pass, tmp2); - } - dead_tmp(tmp); - } else { - return 1; - } - } - } - return 0; -} - -static int disas_cp14_read(CPUState * env, DisasContext *s, uint32_t insn) -{ - int crn = (insn >> 16) & 0xf; - int crm = insn & 0xf; - int op1 = (insn >> 21) & 7; - int op2 = (insn >> 5) & 7; - int rt = (insn >> 12) & 0xf; - TCGv tmp; - - if (arm_feature(env, ARM_FEATURE_THUMB2EE)) { - if (op1 == 6 && crn == 0 && crm == 0 && op2 == 0) { - /* TEECR */ - if (IS_USER(s)) - return 1; - tmp = load_cpu_field(teecr); - store_reg(s, rt, tmp); - return 0; - } - if (op1 == 6 && crn == 1 && crm == 0 && op2 == 0) { - /* TEEHBR */ - if (IS_USER(s) && (env->teecr & 1)) - return 1; - tmp = load_cpu_field(teehbr); - store_reg(s, rt, tmp); - return 0; - } - } - fprintf(stderr, "Unknown cp14 read op1:%d crn:%d crm:%d op2:%d\n", - op1, crn, crm, op2); - return 1; -} - -static int disas_cp14_write(CPUState * env, DisasContext *s, uint32_t insn) -{ - int crn = (insn >> 16) & 0xf; - int crm = insn & 0xf; - int op1 = (insn >> 21) & 7; - int op2 = (insn >> 5) & 7; - int rt = (insn >> 12) & 0xf; - TCGv tmp; - - if (arm_feature(env, ARM_FEATURE_THUMB2EE)) { - if (op1 == 6 && crn == 0 && crm == 0 && op2 == 0) { - /* TEECR */ - if (IS_USER(s)) - return 1; - tmp = load_reg(s, rt); - gen_helper_set_teecr(cpu_env, tmp); - dead_tmp(tmp); - return 0; - } - if (op1 == 6 && crn == 1 && crm == 0 && op2 == 0) { - /* TEEHBR */ - if (IS_USER(s) && (env->teecr & 1)) - return 1; - tmp = load_reg(s, rt); - store_cpu_field(tmp, teehbr); - return 0; - } - } - fprintf(stderr, "Unknown cp14 write op1:%d crn:%d crm:%d op2:%d\n", - op1, crn, crm, op2); - return 1; -} - -static int disas_coproc_insn(CPUState * env, DisasContext *s, uint32_t insn) -{ - int cpnum; - - cpnum = (insn >> 8) & 0xf; - if (arm_feature(env, ARM_FEATURE_XSCALE) - && ((env->cp15.c15_cpar ^ 0x3fff) & (1 << cpnum))) - return 1; - - switch (cpnum) { - case 0: - case 1: - if (arm_feature(env, ARM_FEATURE_IWMMXT)) { - return disas_iwmmxt_insn(env, s, insn); - } else if (arm_feature(env, ARM_FEATURE_XSCALE)) { - return disas_dsp_insn(env, s, insn); - } - return 1; - case 10: - case 11: - return disas_vfp_insn (env, s, insn); - case 14: - /* Coprocessors 7-15 are architecturally reserved by ARM. - Unfortunately Intel decided to ignore this. */ - if (arm_feature(env, ARM_FEATURE_XSCALE)) - goto board; - if (insn & (1 << 20)) - return disas_cp14_read(env, s, insn); - else - return disas_cp14_write(env, s, insn); - case 15: - return disas_cp15_insn (env, s, insn); - default: - board: - /* Unknown coprocessor. See if the board has hooked it. */ - return disas_cp_insn (env, s, insn); - } -} - - -/* Store a 64-bit value to a register pair. Clobbers val. */ -static void gen_storeq_reg(DisasContext *s, int rlow, int rhigh, TCGv_i64 val) -{ - TCGv tmp; - tmp = new_tmp(); - tcg_gen_trunc_i64_i32(tmp, val); - store_reg(s, rlow, tmp); - tmp = new_tmp(); - tcg_gen_shri_i64(val, val, 32); - tcg_gen_trunc_i64_i32(tmp, val); - store_reg(s, rhigh, tmp); -} - -/* load a 32-bit value from a register and perform a 64-bit accumulate. */ -static void gen_addq_lo(DisasContext *s, TCGv_i64 val, int rlow) -{ - TCGv_i64 tmp; - TCGv tmp2; - - /* Load value and extend to 64 bits. */ - tmp = tcg_temp_new_i64(); - tmp2 = load_reg(s, rlow); - tcg_gen_extu_i32_i64(tmp, tmp2); - dead_tmp(tmp2); - tcg_gen_add_i64(val, val, tmp); - tcg_temp_free_i64(tmp); -} - -/* load and add a 64-bit value from a register pair. */ -static void gen_addq(DisasContext *s, TCGv_i64 val, int rlow, int rhigh) -{ - TCGv_i64 tmp; - TCGv tmpl; - TCGv tmph; - - /* Load 64-bit value rd:rn. */ - tmpl = load_reg(s, rlow); - tmph = load_reg(s, rhigh); - tmp = tcg_temp_new_i64(); - tcg_gen_concat_i32_i64(tmp, tmpl, tmph); - dead_tmp(tmpl); - dead_tmp(tmph); - tcg_gen_add_i64(val, val, tmp); - tcg_temp_free_i64(tmp); -} - -/* Set N and Z flags from a 64-bit value. */ -static void gen_logicq_cc(TCGv_i64 val) -{ - TCGv tmp = new_tmp(); - gen_helper_logicq_cc(tmp, val); - gen_logic_CC(tmp); - dead_tmp(tmp); -} - -/* Load/Store exclusive instructions are implemented by remembering - the value/address loaded, and seeing if these are the same - when the store is performed. This should be is sufficient to implement - the architecturally mandated semantics, and avoids having to monitor - regular stores. - - In system emulation mode only one CPU will be running at once, so - this sequence is effectively atomic. In user emulation mode we - throw an exception and handle the atomic operation elsewhere. */ -static void gen_load_exclusive(DisasContext *s, int rt, int rt2, - TCGv addr, int size) -{ - TCGv tmp; - - switch (size) { - case 0: - tmp = gen_ld8u(addr, IS_USER(s)); - break; - case 1: - tmp = gen_ld16u(addr, IS_USER(s)); - break; - case 2: - case 3: - tmp = gen_ld32(addr, IS_USER(s)); - break; - default: - abort(); - } - tcg_gen_mov_i32(cpu_exclusive_val, tmp); - store_reg(s, rt, tmp); - if (size == 3) { - tcg_gen_addi_i32(addr, addr, 4); - tmp = gen_ld32(addr, IS_USER(s)); - tcg_gen_mov_i32(cpu_exclusive_high, tmp); - store_reg(s, rt2, tmp); - } - tcg_gen_mov_i32(cpu_exclusive_addr, addr); -} - -static void gen_clrex(DisasContext *s) -{ - tcg_gen_movi_i32(cpu_exclusive_addr, -1); -} - -#ifdef CONFIG_USER_ONLY -static void gen_store_exclusive(DisasContext *s, int rd, int rt, int rt2, - TCGv addr, int size) -{ - tcg_gen_mov_i32(cpu_exclusive_test, addr); - tcg_gen_movi_i32(cpu_exclusive_info, - size | (rd << 4) | (rt << 8) | (rt2 << 12)); - gen_set_condexec(s); - gen_set_pc_im(s->pc - 4); - gen_exception(EXCP_STREX); - s->is_jmp = DISAS_JUMP; -} -#else -static void gen_store_exclusive(DisasContext *s, int rd, int rt, int rt2, - TCGv addr, int size) -{ - TCGv tmp; - int done_label; - int fail_label; - - /* if (env->exclusive_addr == addr && env->exclusive_val == [addr]) { - [addr] = {Rt}; - {Rd} = 0; - } else { - {Rd} = 1; - } */ - fail_label = gen_new_label(); - done_label = gen_new_label(); - tcg_gen_brcond_i32(TCG_COND_NE, addr, cpu_exclusive_addr, fail_label); - switch (size) { - case 0: - tmp = gen_ld8u(addr, IS_USER(s)); - break; - case 1: - tmp = gen_ld16u(addr, IS_USER(s)); - break; - case 2: - case 3: - tmp = gen_ld32(addr, IS_USER(s)); - break; - default: - abort(); - } - tcg_gen_brcond_i32(TCG_COND_NE, tmp, cpu_exclusive_val, fail_label); - dead_tmp(tmp); - if (size == 3) { - TCGv tmp2 = new_tmp(); - tcg_gen_addi_i32(tmp2, addr, 4); - tmp = gen_ld32(addr, IS_USER(s)); - dead_tmp(tmp2); - tcg_gen_brcond_i32(TCG_COND_NE, tmp, cpu_exclusive_high, fail_label); - dead_tmp(tmp); - } - tmp = load_reg(s, rt); - switch (size) { - case 0: - gen_st8(tmp, addr, IS_USER(s)); - break; - case 1: - gen_st16(tmp, addr, IS_USER(s)); - break; - case 2: - case 3: - gen_st32(tmp, addr, IS_USER(s)); - break; - default: - abort(); - } - if (size == 3) { - tcg_gen_addi_i32(addr, addr, 4); - tmp = load_reg(s, rt2); - gen_st32(tmp, addr, IS_USER(s)); - } - tcg_gen_movi_i32(cpu_R[rd], 0); - tcg_gen_br(done_label); - gen_set_label(fail_label); - tcg_gen_movi_i32(cpu_R[rd], 1); - gen_set_label(done_label); - tcg_gen_movi_i32(cpu_exclusive_addr, -1); -} -#endif - -static void disas_arm_insn(CPUState * env, DisasContext *s) -{ - unsigned int cond, insn, val, op1, i, shift, rm, rs, rn, rd, sh; - TCGv tmp; - TCGv tmp2; - TCGv tmp3; - TCGv addr; - TCGv_i64 tmp64; - - insn = ldl_code(s->pc); - s->pc += 4; - - /* M variants do not implement ARM mode. */ - if (IS_M(env)) - goto illegal_op; - cond = insn >> 28; - if (cond == 0xf){ - /* Unconditional instructions. */ - if (((insn >> 25) & 7) == 1) { - /* NEON Data processing. */ - if (!arm_feature(env, ARM_FEATURE_NEON)) - goto illegal_op; - - if (disas_neon_data_insn(env, s, insn)) - goto illegal_op; - return; - } - if ((insn & 0x0f100000) == 0x04000000) { - /* NEON load/store. */ - if (!arm_feature(env, ARM_FEATURE_NEON)) - goto illegal_op; - - if (disas_neon_ls_insn(env, s, insn)) - goto illegal_op; - return; - } - if ((insn & 0x0d70f000) == 0x0550f000) - return; /* PLD */ - else if ((insn & 0x0ffffdff) == 0x01010000) { - ARCH(6); - /* setend */ - if (insn & (1 << 9)) { - /* BE8 mode not implemented. */ - goto illegal_op; - } - return; - } else if ((insn & 0x0fffff00) == 0x057ff000) { - switch ((insn >> 4) & 0xf) { - case 1: /* clrex */ - ARCH(6K); - gen_clrex(s); - return; - case 4: /* dsb */ - case 5: /* dmb */ - case 6: /* isb */ - ARCH(7); - /* We don't emulate caches so these are a no-op. */ - return; - default: - goto illegal_op; - } - } else if ((insn & 0x0e5fffe0) == 0x084d0500) { - /* srs */ - int32_t offset; - if (IS_USER(s)) - goto illegal_op; - ARCH(6); - op1 = (insn & 0x1f); - if (op1 == (env->uncached_cpsr & CPSR_M)) { - addr = load_reg(s, 13); - } else { - addr = new_tmp(); - tmp = tcg_const_i32(op1); - gen_helper_get_r13_banked(addr, cpu_env, tmp); - tcg_temp_free_i32(tmp); - } - i = (insn >> 23) & 3; - switch (i) { - case 0: offset = -4; break; /* DA */ - case 1: offset = 0; break; /* IA */ - case 2: offset = -8; break; /* DB */ - case 3: offset = 4; break; /* IB */ - default: abort(); - } - if (offset) - tcg_gen_addi_i32(addr, addr, offset); - tmp = load_reg(s, 14); - gen_st32(tmp, addr, 0); - tmp = load_cpu_field(spsr); - tcg_gen_addi_i32(addr, addr, 4); - gen_st32(tmp, addr, 0); - if (insn & (1 << 21)) { - /* Base writeback. */ - switch (i) { - case 0: offset = -8; break; - case 1: offset = 4; break; - case 2: offset = -4; break; - case 3: offset = 0; break; - default: abort(); - } - if (offset) - tcg_gen_addi_i32(addr, addr, offset); - if (op1 == (env->uncached_cpsr & CPSR_M)) { - store_reg(s, 13, addr); - } else { - tmp = tcg_const_i32(op1); - gen_helper_set_r13_banked(cpu_env, tmp, addr); - tcg_temp_free_i32(tmp); - dead_tmp(addr); - } - } else { - dead_tmp(addr); - } - } else if ((insn & 0x0e5fffe0) == 0x081d0a00) { - /* rfe */ - int32_t offset; - if (IS_USER(s)) - goto illegal_op; - ARCH(6); - rn = (insn >> 16) & 0xf; - addr = load_reg(s, rn); - i = (insn >> 23) & 3; - switch (i) { - case 0: offset = -4; break; /* DA */ - case 1: offset = 0; break; /* IA */ - case 2: offset = -8; break; /* DB */ - case 3: offset = 4; break; /* IB */ - default: abort(); - } - if (offset) - tcg_gen_addi_i32(addr, addr, offset); - /* Load PC into tmp and CPSR into tmp2. */ - tmp = gen_ld32(addr, 0); - tcg_gen_addi_i32(addr, addr, 4); - tmp2 = gen_ld32(addr, 0); - if (insn & (1 << 21)) { - /* Base writeback. */ - switch (i) { - case 0: offset = -8; break; - case 1: offset = 4; break; - case 2: offset = -4; break; - case 3: offset = 0; break; - default: abort(); - } - if (offset) - tcg_gen_addi_i32(addr, addr, offset); - store_reg(s, rn, addr); - } else { - dead_tmp(addr); - } - gen_rfe(s, tmp, tmp2); - return; - } else if ((insn & 0x0e000000) == 0x0a000000) { - /* branch link and change to thumb (blx ) */ - int32_t offset; - - val = (uint32_t)s->pc; - tmp = new_tmp(); - tcg_gen_movi_i32(tmp, val); - store_reg(s, 14, tmp); - /* Sign-extend the 24-bit offset */ - offset = (((int32_t)insn) << 8) >> 8; - /* offset * 4 + bit24 * 2 + (thumb bit) */ - val += (offset << 2) | ((insn >> 23) & 2) | 1; - /* pipeline offset */ - val += 4; - gen_bx_im(s, val); - return; - } else if ((insn & 0x0e000f00) == 0x0c000100) { - if (arm_feature(env, ARM_FEATURE_IWMMXT)) { - /* iWMMXt register transfer. */ - if (env->cp15.c15_cpar & (1 << 1)) - if (!disas_iwmmxt_insn(env, s, insn)) - return; - } - } else if ((insn & 0x0fe00000) == 0x0c400000) { - /* Coprocessor double register transfer. */ - } else if ((insn & 0x0f000010) == 0x0e000010) { - /* Additional coprocessor register transfer. */ - } else if ((insn & 0x0ff10020) == 0x01000000) { - uint32_t mask; - uint32_t val; - /* cps (privileged) */ - if (IS_USER(s)) - return; - mask = val = 0; - if (insn & (1 << 19)) { - if (insn & (1 << 8)) - mask |= CPSR_A; - if (insn & (1 << 7)) - mask |= CPSR_I; - if (insn & (1 << 6)) - mask |= CPSR_F; - if (insn & (1 << 18)) - val |= mask; - } - if (insn & (1 << 17)) { - mask |= CPSR_M; - val |= (insn & 0x1f); - } - if (mask) { - gen_set_psr_im(s, mask, 0, val); - } - return; - } - goto illegal_op; - } - if (cond != 0xe) { - /* if not always execute, we generate a conditional jump to - next instruction */ - s->condlabel = gen_new_label(); - gen_test_cc(cond ^ 1, s->condlabel); - s->condjmp = 1; - } - if ((insn & 0x0f900000) == 0x03000000) { - if ((insn & (1 << 21)) == 0) { - ARCH(6T2); - rd = (insn >> 12) & 0xf; - val = ((insn >> 4) & 0xf000) | (insn & 0xfff); - if ((insn & (1 << 22)) == 0) { - /* MOVW */ - tmp = new_tmp(); - tcg_gen_movi_i32(tmp, val); - } else { - /* MOVT */ - tmp = load_reg(s, rd); - tcg_gen_ext16u_i32(tmp, tmp); - tcg_gen_ori_i32(tmp, tmp, val << 16); - } - store_reg(s, rd, tmp); - } else { - if (((insn >> 12) & 0xf) != 0xf) - goto illegal_op; - if (((insn >> 16) & 0xf) == 0) { - gen_nop_hint(s, insn & 0xff); - } else { - /* CPSR = immediate */ - val = insn & 0xff; - shift = ((insn >> 8) & 0xf) * 2; - if (shift) - val = (val >> shift) | (val << (32 - shift)); - i = ((insn & (1 << 22)) != 0); - if (gen_set_psr_im(s, msr_mask(env, s, (insn >> 16) & 0xf, i), i, val)) - goto illegal_op; - } - } - } else if ((insn & 0x0f900000) == 0x01000000 - && (insn & 0x00000090) != 0x00000090) { - /* miscellaneous instructions */ - op1 = (insn >> 21) & 3; - sh = (insn >> 4) & 0xf; - rm = insn & 0xf; - switch (sh) { - case 0x0: /* move program status register */ - if (op1 & 1) { - /* PSR = reg */ - tmp = load_reg(s, rm); - i = ((op1 & 2) != 0); - if (gen_set_psr(s, msr_mask(env, s, (insn >> 16) & 0xf, i), i, tmp)) - goto illegal_op; - } else { - /* reg = PSR */ - rd = (insn >> 12) & 0xf; - if (op1 & 2) { - if (IS_USER(s)) - goto illegal_op; - tmp = load_cpu_field(spsr); - } else { - tmp = new_tmp(); - gen_helper_cpsr_read(tmp); - } - store_reg(s, rd, tmp); - } - break; - case 0x1: - if (op1 == 1) { - /* branch/exchange thumb (bx). */ - tmp = load_reg(s, rm); - gen_bx(s, tmp); - } else if (op1 == 3) { - /* clz */ - rd = (insn >> 12) & 0xf; - tmp = load_reg(s, rm); - gen_helper_clz(tmp, tmp); - store_reg(s, rd, tmp); - } else { - goto illegal_op; - } - break; - case 0x2: - if (op1 == 1) { - ARCH(5J); /* bxj */ - /* Trivial implementation equivalent to bx. */ - tmp = load_reg(s, rm); - gen_bx(s, tmp); - } else { - goto illegal_op; - } - break; - case 0x3: - if (op1 != 1) - goto illegal_op; - - /* branch link/exchange thumb (blx) */ - tmp = load_reg(s, rm); - tmp2 = new_tmp(); - tcg_gen_movi_i32(tmp2, s->pc); - store_reg(s, 14, tmp2); - gen_bx(s, tmp); - break; - case 0x5: /* saturating add/subtract */ - rd = (insn >> 12) & 0xf; - rn = (insn >> 16) & 0xf; - tmp = load_reg(s, rm); - tmp2 = load_reg(s, rn); - if (op1 & 2) - gen_helper_double_saturate(tmp2, tmp2); - if (op1 & 1) - gen_helper_sub_saturate(tmp, tmp, tmp2); - else - gen_helper_add_saturate(tmp, tmp, tmp2); - dead_tmp(tmp2); - store_reg(s, rd, tmp); - break; - case 7: /* bkpt */ - gen_set_condexec(s); - gen_set_pc_im(s->pc - 4); - gen_exception(EXCP_BKPT); - s->is_jmp = DISAS_JUMP; - break; - case 0x8: /* signed multiply */ - case 0xa: - case 0xc: - case 0xe: - rs = (insn >> 8) & 0xf; - rn = (insn >> 12) & 0xf; - rd = (insn >> 16) & 0xf; - if (op1 == 1) { - /* (32 * 16) >> 16 */ - tmp = load_reg(s, rm); - tmp2 = load_reg(s, rs); - if (sh & 4) - tcg_gen_sari_i32(tmp2, tmp2, 16); - else - gen_sxth(tmp2); - tmp64 = gen_muls_i64_i32(tmp, tmp2); - tcg_gen_shri_i64(tmp64, tmp64, 16); - tmp = new_tmp(); - tcg_gen_trunc_i64_i32(tmp, tmp64); - tcg_temp_free_i64(tmp64); - if ((sh & 2) == 0) { - tmp2 = load_reg(s, rn); - gen_helper_add_setq(tmp, tmp, tmp2); - dead_tmp(tmp2); - } - store_reg(s, rd, tmp); - } else { - /* 16 * 16 */ - tmp = load_reg(s, rm); - tmp2 = load_reg(s, rs); - gen_mulxy(tmp, tmp2, sh & 2, sh & 4); - dead_tmp(tmp2); - if (op1 == 2) { - tmp64 = tcg_temp_new_i64(); - tcg_gen_ext_i32_i64(tmp64, tmp); - dead_tmp(tmp); - gen_addq(s, tmp64, rn, rd); - gen_storeq_reg(s, rn, rd, tmp64); - tcg_temp_free_i64(tmp64); - } else { - if (op1 == 0) { - tmp2 = load_reg(s, rn); - gen_helper_add_setq(tmp, tmp, tmp2); - dead_tmp(tmp2); - } - store_reg(s, rd, tmp); - } - } - break; - default: - goto illegal_op; - } - } else if (((insn & 0x0e000000) == 0 && - (insn & 0x00000090) != 0x90) || - ((insn & 0x0e000000) == (1 << 25))) { - int set_cc, logic_cc, shiftop; - - op1 = (insn >> 21) & 0xf; - set_cc = (insn >> 20) & 1; - logic_cc = table_logic_cc[op1] & set_cc; - - /* data processing instruction */ - if (insn & (1 << 25)) { - /* immediate operand */ - val = insn & 0xff; - shift = ((insn >> 8) & 0xf) * 2; - if (shift) { - val = (val >> shift) | (val << (32 - shift)); - } - tmp2 = new_tmp(); - tcg_gen_movi_i32(tmp2, val); - if (logic_cc && shift) { - gen_set_CF_bit31(tmp2); - } - } else { - /* register */ - rm = (insn) & 0xf; - tmp2 = load_reg(s, rm); - shiftop = (insn >> 5) & 3; - if (!(insn & (1 << 4))) { - shift = (insn >> 7) & 0x1f; - gen_arm_shift_im(tmp2, shiftop, shift, logic_cc); - } else { - rs = (insn >> 8) & 0xf; - tmp = load_reg(s, rs); - gen_arm_shift_reg(tmp2, shiftop, tmp, logic_cc); - } - } - if (op1 != 0x0f && op1 != 0x0d) { - rn = (insn >> 16) & 0xf; - tmp = load_reg(s, rn); - } else { - TCGV_UNUSED(tmp); - } - rd = (insn >> 12) & 0xf; - switch(op1) { - case 0x00: - tcg_gen_and_i32(tmp, tmp, tmp2); - if (logic_cc) { - gen_logic_CC(tmp); - } - store_reg_bx(env, s, rd, tmp); - break; - case 0x01: - tcg_gen_xor_i32(tmp, tmp, tmp2); - if (logic_cc) { - gen_logic_CC(tmp); - } - store_reg_bx(env, s, rd, tmp); - break; - case 0x02: - if (set_cc && rd == 15) { - /* SUBS r15, ... is used for exception return. */ - if (IS_USER(s)) { - goto illegal_op; - } - gen_helper_sub_cc(tmp, tmp, tmp2); - gen_exception_return(s, tmp); - } else { - if (set_cc) { - gen_helper_sub_cc(tmp, tmp, tmp2); - } else { - tcg_gen_sub_i32(tmp, tmp, tmp2); - } - store_reg_bx(env, s, rd, tmp); - } - break; - case 0x03: - if (set_cc) { - gen_helper_sub_cc(tmp, tmp2, tmp); - } else { - tcg_gen_sub_i32(tmp, tmp2, tmp); - } - store_reg_bx(env, s, rd, tmp); - break; - case 0x04: - if (set_cc) { - gen_helper_add_cc(tmp, tmp, tmp2); - } else { - tcg_gen_add_i32(tmp, tmp, tmp2); - } - store_reg_bx(env, s, rd, tmp); - break; - case 0x05: - if (set_cc) { - gen_helper_adc_cc(tmp, tmp, tmp2); - } else { - gen_add_carry(tmp, tmp, tmp2); - } - store_reg_bx(env, s, rd, tmp); - break; - case 0x06: - if (set_cc) { - gen_helper_sbc_cc(tmp, tmp, tmp2); - } else { - gen_sub_carry(tmp, tmp, tmp2); - } - store_reg_bx(env, s, rd, tmp); - break; - case 0x07: - if (set_cc) { - gen_helper_sbc_cc(tmp, tmp2, tmp); - } else { - gen_sub_carry(tmp, tmp2, tmp); - } - store_reg_bx(env, s, rd, tmp); - break; - case 0x08: - if (set_cc) { - tcg_gen_and_i32(tmp, tmp, tmp2); - gen_logic_CC(tmp); - } - dead_tmp(tmp); - break; - case 0x09: - if (set_cc) { - tcg_gen_xor_i32(tmp, tmp, tmp2); - gen_logic_CC(tmp); - } - dead_tmp(tmp); - break; - case 0x0a: - if (set_cc) { - gen_helper_sub_cc(tmp, tmp, tmp2); - } - dead_tmp(tmp); - break; - case 0x0b: - if (set_cc) { - gen_helper_add_cc(tmp, tmp, tmp2); - } - dead_tmp(tmp); - break; - case 0x0c: - tcg_gen_or_i32(tmp, tmp, tmp2); - if (logic_cc) { - gen_logic_CC(tmp); - } - store_reg_bx(env, s, rd, tmp); - break; - case 0x0d: - if (logic_cc && rd == 15) { - /* MOVS r15, ... is used for exception return. */ - if (IS_USER(s)) { - goto illegal_op; - } - gen_exception_return(s, tmp2); - } else { - if (logic_cc) { - gen_logic_CC(tmp2); - } - store_reg_bx(env, s, rd, tmp2); - } - break; - case 0x0e: - tcg_gen_andc_i32(tmp, tmp, tmp2); - if (logic_cc) { - gen_logic_CC(tmp); - } - store_reg_bx(env, s, rd, tmp); - break; - default: - case 0x0f: - tcg_gen_not_i32(tmp2, tmp2); - if (logic_cc) { - gen_logic_CC(tmp2); - } - store_reg_bx(env, s, rd, tmp2); - break; - } - if (op1 != 0x0f && op1 != 0x0d) { - dead_tmp(tmp2); - } - } else { - /* other instructions */ - op1 = (insn >> 24) & 0xf; - switch(op1) { - case 0x0: - case 0x1: - /* multiplies, extra load/stores */ - sh = (insn >> 5) & 3; - if (sh == 0) { - if (op1 == 0x0) { - rd = (insn >> 16) & 0xf; - rn = (insn >> 12) & 0xf; - rs = (insn >> 8) & 0xf; - rm = (insn) & 0xf; - op1 = (insn >> 20) & 0xf; - switch (op1) { - case 0: case 1: case 2: case 3: case 6: - /* 32 bit mul */ - tmp = load_reg(s, rs); - tmp2 = load_reg(s, rm); - tcg_gen_mul_i32(tmp, tmp, tmp2); - dead_tmp(tmp2); - if (insn & (1 << 22)) { - /* Subtract (mls) */ - ARCH(6T2); - tmp2 = load_reg(s, rn); - tcg_gen_sub_i32(tmp, tmp2, tmp); - dead_tmp(tmp2); - } else if (insn & (1 << 21)) { - /* Add */ - tmp2 = load_reg(s, rn); - tcg_gen_add_i32(tmp, tmp, tmp2); - dead_tmp(tmp2); - } - if (insn & (1 << 20)) - gen_logic_CC(tmp); - store_reg(s, rd, tmp); - break; - default: - /* 64 bit mul */ - tmp = load_reg(s, rs); - tmp2 = load_reg(s, rm); - if (insn & (1 << 22)) - tmp64 = gen_muls_i64_i32(tmp, tmp2); - else - tmp64 = gen_mulu_i64_i32(tmp, tmp2); - if (insn & (1 << 21)) /* mult accumulate */ - gen_addq(s, tmp64, rn, rd); - if (!(insn & (1 << 23))) { /* double accumulate */ - ARCH(6); - gen_addq_lo(s, tmp64, rn); - gen_addq_lo(s, tmp64, rd); - } - if (insn & (1 << 20)) - gen_logicq_cc(tmp64); - gen_storeq_reg(s, rn, rd, tmp64); - tcg_temp_free_i64(tmp64); - break; - } - } else { - rn = (insn >> 16) & 0xf; - rd = (insn >> 12) & 0xf; - if (insn & (1 << 23)) { - /* load/store exclusive */ - op1 = (insn >> 21) & 0x3; - if (op1) - ARCH(6K); - else - ARCH(6); - addr = tcg_temp_local_new_i32(); - load_reg_var(s, addr, rn); - if (insn & (1 << 20)) { - switch (op1) { - case 0: /* ldrex */ - gen_load_exclusive(s, rd, 15, addr, 2); - break; - case 1: /* ldrexd */ - gen_load_exclusive(s, rd, rd + 1, addr, 3); - break; - case 2: /* ldrexb */ - gen_load_exclusive(s, rd, 15, addr, 0); - break; - case 3: /* ldrexh */ - gen_load_exclusive(s, rd, 15, addr, 1); - break; - default: - abort(); - } - } else { - rm = insn & 0xf; - switch (op1) { - case 0: /* strex */ - gen_store_exclusive(s, rd, rm, 15, addr, 2); - break; - case 1: /* strexd */ - gen_store_exclusive(s, rd, rm, rm + 1, addr, 3); - break; - case 2: /* strexb */ - gen_store_exclusive(s, rd, rm, 15, addr, 0); - break; - case 3: /* strexh */ - gen_store_exclusive(s, rd, rm, 15, addr, 1); - break; - default: - abort(); - } - } - tcg_temp_free(addr); - } else { - /* SWP instruction */ - rm = (insn) & 0xf; - - /* ??? This is not really atomic. However we know - we never have multiple CPUs running in parallel, - so it is good enough. */ - addr = load_reg(s, rn); - tmp = load_reg(s, rm); - if (insn & (1 << 22)) { - tmp2 = gen_ld8u(addr, IS_USER(s)); - gen_st8(tmp, addr, IS_USER(s)); - } else { - tmp2 = gen_ld32(addr, IS_USER(s)); - gen_st32(tmp, addr, IS_USER(s)); - } - dead_tmp(addr); - store_reg(s, rd, tmp2); - } - } - } else { - int address_offset; - int load; - /* Misc load/store */ - rn = (insn >> 16) & 0xf; - rd = (insn >> 12) & 0xf; - addr = load_reg(s, rn); - if (insn & (1 << 24)) - gen_add_datah_offset(s, insn, 0, addr); - address_offset = 0; - if (insn & (1 << 20)) { - /* load */ - switch(sh) { - case 1: - tmp = gen_ld16u(addr, IS_USER(s)); - break; - case 2: - tmp = gen_ld8s(addr, IS_USER(s)); - break; - default: - case 3: - tmp = gen_ld16s(addr, IS_USER(s)); - break; - } - load = 1; - } else if (sh & 2) { - /* doubleword */ - if (sh & 1) { - /* store */ - tmp = load_reg(s, rd); - gen_st32(tmp, addr, IS_USER(s)); - tcg_gen_addi_i32(addr, addr, 4); - tmp = load_reg(s, rd + 1); - gen_st32(tmp, addr, IS_USER(s)); - load = 0; - } else { - /* load */ - tmp = gen_ld32(addr, IS_USER(s)); - store_reg(s, rd, tmp); - tcg_gen_addi_i32(addr, addr, 4); - tmp = gen_ld32(addr, IS_USER(s)); - rd++; - load = 1; - } - address_offset = -4; - } else { - /* store */ - tmp = load_reg(s, rd); - gen_st16(tmp, addr, IS_USER(s)); - load = 0; - } - /* Perform base writeback before the loaded value to - ensure correct behavior with overlapping index registers. - ldrd with base writeback is is undefined if the - destination and index registers overlap. */ - if (!(insn & (1 << 24))) { - gen_add_datah_offset(s, insn, address_offset, addr); - store_reg(s, rn, addr); - } else if (insn & (1 << 21)) { - if (address_offset) - tcg_gen_addi_i32(addr, addr, address_offset); - store_reg(s, rn, addr); - } else { - dead_tmp(addr); - } - if (load) { - /* Complete the load. */ - store_reg(s, rd, tmp); - } - } - break; - case 0x4: - case 0x5: - goto do_ldst; - case 0x6: - case 0x7: - if (insn & (1 << 4)) { - ARCH(6); - /* Armv6 Media instructions. */ - rm = insn & 0xf; - rn = (insn >> 16) & 0xf; - rd = (insn >> 12) & 0xf; - rs = (insn >> 8) & 0xf; - switch ((insn >> 23) & 3) { - case 0: /* Parallel add/subtract. */ - op1 = (insn >> 20) & 7; - tmp = load_reg(s, rn); - tmp2 = load_reg(s, rm); - sh = (insn >> 5) & 7; - if ((op1 & 3) == 0 || sh == 5 || sh == 6) - goto illegal_op; - gen_arm_parallel_addsub(op1, sh, tmp, tmp2); - dead_tmp(tmp2); - store_reg(s, rd, tmp); - break; - case 1: - if ((insn & 0x00700020) == 0) { - /* Halfword pack. */ - tmp = load_reg(s, rn); - tmp2 = load_reg(s, rm); - shift = (insn >> 7) & 0x1f; - if (insn & (1 << 6)) { - /* pkhtb */ - if (shift == 0) - shift = 31; - tcg_gen_sari_i32(tmp2, tmp2, shift); - tcg_gen_andi_i32(tmp, tmp, 0xffff0000); - tcg_gen_ext16u_i32(tmp2, tmp2); - } else { - /* pkhbt */ - if (shift) - tcg_gen_shli_i32(tmp2, tmp2, shift); - tcg_gen_ext16u_i32(tmp, tmp); - tcg_gen_andi_i32(tmp2, tmp2, 0xffff0000); - } - tcg_gen_or_i32(tmp, tmp, tmp2); - dead_tmp(tmp2); - store_reg(s, rd, tmp); - } else if ((insn & 0x00200020) == 0x00200000) { - /* [us]sat */ - tmp = load_reg(s, rm); - shift = (insn >> 7) & 0x1f; - if (insn & (1 << 6)) { - if (shift == 0) - shift = 31; - tcg_gen_sari_i32(tmp, tmp, shift); - } else { - tcg_gen_shli_i32(tmp, tmp, shift); - } - sh = (insn >> 16) & 0x1f; - if (sh != 0) { - tmp2 = tcg_const_i32(sh); - if (insn & (1 << 22)) - gen_helper_usat(tmp, tmp, tmp2); - else - gen_helper_ssat(tmp, tmp, tmp2); - tcg_temp_free_i32(tmp2); - } - store_reg(s, rd, tmp); - } else if ((insn & 0x00300fe0) == 0x00200f20) { - /* [us]sat16 */ - tmp = load_reg(s, rm); - sh = (insn >> 16) & 0x1f; - if (sh != 0) { - tmp2 = tcg_const_i32(sh); - if (insn & (1 << 22)) - gen_helper_usat16(tmp, tmp, tmp2); - else - gen_helper_ssat16(tmp, tmp, tmp2); - tcg_temp_free_i32(tmp2); - } - store_reg(s, rd, tmp); - } else if ((insn & 0x00700fe0) == 0x00000fa0) { - /* Select bytes. */ - tmp = load_reg(s, rn); - tmp2 = load_reg(s, rm); - tmp3 = new_tmp(); - tcg_gen_ld_i32(tmp3, cpu_env, offsetof(CPUState, GE)); - gen_helper_sel_flags(tmp, tmp3, tmp, tmp2); - dead_tmp(tmp3); - dead_tmp(tmp2); - store_reg(s, rd, tmp); - } else if ((insn & 0x000003e0) == 0x00000060) { - tmp = load_reg(s, rm); - shift = (insn >> 10) & 3; - /* ??? In many cases it's not neccessary to do a - rotate, a shift is sufficient. */ - if (shift != 0) - tcg_gen_rotri_i32(tmp, tmp, shift * 8); - op1 = (insn >> 20) & 7; - switch (op1) { - case 0: gen_sxtb16(tmp); break; - case 2: gen_sxtb(tmp); break; - case 3: gen_sxth(tmp); break; - case 4: gen_uxtb16(tmp); break; - case 6: gen_uxtb(tmp); break; - case 7: gen_uxth(tmp); break; - default: goto illegal_op; - } - if (rn != 15) { - tmp2 = load_reg(s, rn); - if ((op1 & 3) == 0) { - gen_add16(tmp, tmp2); - } else { - tcg_gen_add_i32(tmp, tmp, tmp2); - dead_tmp(tmp2); - } - } - store_reg(s, rd, tmp); - } else if ((insn & 0x003f0f60) == 0x003f0f20) { - /* rev */ - tmp = load_reg(s, rm); - if (insn & (1 << 22)) { - if (insn & (1 << 7)) { - gen_revsh(tmp); - } else { - ARCH(6T2); - gen_helper_rbit(tmp, tmp); - } - } else { - if (insn & (1 << 7)) - gen_rev16(tmp); - else - tcg_gen_bswap32_i32(tmp, tmp); - } - store_reg(s, rd, tmp); - } else { - goto illegal_op; - } - break; - case 2: /* Multiplies (Type 3). */ - tmp = load_reg(s, rm); - tmp2 = load_reg(s, rs); - if (insn & (1 << 20)) { - /* Signed multiply most significant [accumulate]. */ - tmp64 = gen_muls_i64_i32(tmp, tmp2); - if (insn & (1 << 5)) - tcg_gen_addi_i64(tmp64, tmp64, 0x80000000u); - tcg_gen_shri_i64(tmp64, tmp64, 32); - tmp = new_tmp(); - tcg_gen_trunc_i64_i32(tmp, tmp64); - tcg_temp_free_i64(tmp64); - if (rd != 15) { - tmp2 = load_reg(s, rd); - if (insn & (1 << 6)) { - tcg_gen_sub_i32(tmp, tmp, tmp2); - } else { - tcg_gen_add_i32(tmp, tmp, tmp2); - } - dead_tmp(tmp2); - } - store_reg(s, rn, tmp); - } else { - if (insn & (1 << 5)) - gen_swap_half(tmp2); - gen_smul_dual(tmp, tmp2); - /* This addition cannot overflow. */ - if (insn & (1 << 6)) { - tcg_gen_sub_i32(tmp, tmp, tmp2); - } else { - tcg_gen_add_i32(tmp, tmp, tmp2); - } - dead_tmp(tmp2); - if (insn & (1 << 22)) { - /* smlald, smlsld */ - tmp64 = tcg_temp_new_i64(); - tcg_gen_ext_i32_i64(tmp64, tmp); - dead_tmp(tmp); - gen_addq(s, tmp64, rd, rn); - gen_storeq_reg(s, rd, rn, tmp64); - tcg_temp_free_i64(tmp64); - } else { - /* smuad, smusd, smlad, smlsd */ - if (rd != 15) - { - tmp2 = load_reg(s, rd); - gen_helper_add_setq(tmp, tmp, tmp2); - dead_tmp(tmp2); - } - store_reg(s, rn, tmp); - } - } - break; - case 3: - op1 = ((insn >> 17) & 0x38) | ((insn >> 5) & 7); - switch (op1) { - case 0: /* Unsigned sum of absolute differences. */ - ARCH(6); - tmp = load_reg(s, rm); - tmp2 = load_reg(s, rs); - gen_helper_usad8(tmp, tmp, tmp2); - dead_tmp(tmp2); - if (rd != 15) { - tmp2 = load_reg(s, rd); - tcg_gen_add_i32(tmp, tmp, tmp2); - dead_tmp(tmp2); - } - store_reg(s, rn, tmp); - break; - case 0x20: case 0x24: case 0x28: case 0x2c: - /* Bitfield insert/clear. */ - ARCH(6T2); - shift = (insn >> 7) & 0x1f; - i = (insn >> 16) & 0x1f; - i = i + 1 - shift; - if (rm == 15) { - tmp = new_tmp(); - tcg_gen_movi_i32(tmp, 0); - } else { - tmp = load_reg(s, rm); - } - if (i != 32) { - tmp2 = load_reg(s, rd); - gen_bfi(tmp, tmp2, tmp, shift, (1u << i) - 1); - dead_tmp(tmp2); - } - store_reg(s, rd, tmp); - break; - case 0x12: case 0x16: case 0x1a: case 0x1e: /* sbfx */ - case 0x32: case 0x36: case 0x3a: case 0x3e: /* ubfx */ - ARCH(6T2); - tmp = load_reg(s, rm); - shift = (insn >> 7) & 0x1f; - i = ((insn >> 16) & 0x1f) + 1; - if (shift + i > 32) - goto illegal_op; - if (i < 32) { - if (op1 & 0x20) { - gen_ubfx(tmp, shift, (1u << i) - 1); - } else { - gen_sbfx(tmp, shift, i); - } - } - store_reg(s, rd, tmp); - break; - default: - goto illegal_op; - } - break; - } - break; - } - do_ldst: - /* Check for undefined extension instructions - * per the ARM Bible IE: - * xxxx 0111 1111 xxxx xxxx xxxx 1111 xxxx - */ - sh = (0xf << 20) | (0xf << 4); - if (op1 == 0x7 && ((insn & sh) == sh)) - { - goto illegal_op; - } - /* load/store byte/word */ - rn = (insn >> 16) & 0xf; - rd = (insn >> 12) & 0xf; - tmp2 = load_reg(s, rn); - i = (IS_USER(s) || (insn & 0x01200000) == 0x00200000); - if (insn & (1 << 24)) - gen_add_data_offset(s, insn, tmp2); - if (insn & (1 << 20)) { - /* load */ - if (insn & (1 << 22)) { - tmp = gen_ld8u(tmp2, i); - } else { - tmp = gen_ld32(tmp2, i); - } - } else { - /* store */ - tmp = load_reg(s, rd); - if (insn & (1 << 22)) - gen_st8(tmp, tmp2, i); - else - gen_st32(tmp, tmp2, i); - } - if (!(insn & (1 << 24))) { - gen_add_data_offset(s, insn, tmp2); - store_reg(s, rn, tmp2); - } else if (insn & (1 << 21)) { - store_reg(s, rn, tmp2); - } else { - dead_tmp(tmp2); - } - if (insn & (1 << 20)) { - /* Complete the load. */ - if (rd == 15) - gen_bx(s, tmp); - else - store_reg(s, rd, tmp); - } - break; - case 0x08: - case 0x09: - { - int j, n, user, loaded_base; - TCGv loaded_var; - /* load/store multiple words */ - /* XXX: store correct base if write back */ - user = 0; - if (insn & (1 << 22)) { - if (IS_USER(s)) - goto illegal_op; /* only usable in supervisor mode */ - - if ((insn & (1 << 15)) == 0) - user = 1; - } - rn = (insn >> 16) & 0xf; - addr = load_reg(s, rn); - - /* compute total size */ - loaded_base = 0; - TCGV_UNUSED(loaded_var); - n = 0; - for(i=0;i<16;i++) { - if (insn & (1 << i)) - n++; - } - /* XXX: test invalid n == 0 case ? */ - if (insn & (1 << 23)) { - if (insn & (1 << 24)) { - /* pre increment */ - tcg_gen_addi_i32(addr, addr, 4); - } else { - /* post increment */ - } - } else { - if (insn & (1 << 24)) { - /* pre decrement */ - tcg_gen_addi_i32(addr, addr, -(n * 4)); - } else { - /* post decrement */ - if (n != 1) - tcg_gen_addi_i32(addr, addr, -((n - 1) * 4)); - } - } - j = 0; - for(i=0;i<16;i++) { - if (insn & (1 << i)) { - if (insn & (1 << 20)) { - /* load */ - tmp = gen_ld32(addr, IS_USER(s)); - if (i == 15) { - gen_bx(s, tmp); - } else if (user) { - tmp2 = tcg_const_i32(i); - gen_helper_set_user_reg(tmp2, tmp); - tcg_temp_free_i32(tmp2); - dead_tmp(tmp); - } else if (i == rn) { - loaded_var = tmp; - loaded_base = 1; - } else { - store_reg(s, i, tmp); - } - } else { - /* store */ - if (i == 15) { - /* special case: r15 = PC + 8 */ - val = (long)s->pc + 4; - tmp = new_tmp(); - tcg_gen_movi_i32(tmp, val); - } else if (user) { - tmp = new_tmp(); - tmp2 = tcg_const_i32(i); - gen_helper_get_user_reg(tmp, tmp2); - tcg_temp_free_i32(tmp2); - } else { - tmp = load_reg(s, i); - } - gen_st32(tmp, addr, IS_USER(s)); - } - j++; - /* no need to add after the last transfer */ - if (j != n) - tcg_gen_addi_i32(addr, addr, 4); - } - } - if (insn & (1 << 21)) { - /* write back */ - if (insn & (1 << 23)) { - if (insn & (1 << 24)) { - /* pre increment */ - } else { - /* post increment */ - tcg_gen_addi_i32(addr, addr, 4); - } - } else { - if (insn & (1 << 24)) { - /* pre decrement */ - if (n != 1) - tcg_gen_addi_i32(addr, addr, -((n - 1) * 4)); - } else { - /* post decrement */ - tcg_gen_addi_i32(addr, addr, -(n * 4)); - } - } - store_reg(s, rn, addr); - } else { - dead_tmp(addr); - } - if (loaded_base) { - store_reg(s, rn, loaded_var); - } - if ((insn & (1 << 22)) && !user) { - /* Restore CPSR from SPSR. */ - tmp = load_cpu_field(spsr); - gen_set_cpsr(tmp, 0xffffffff); - dead_tmp(tmp); - s->is_jmp = DISAS_UPDATE; - } - } - break; - case 0xa: - case 0xb: - { - int32_t offset; - - /* branch (and link) */ - val = (int32_t)s->pc; - if (insn & (1 << 24)) { - tmp = new_tmp(); - tcg_gen_movi_i32(tmp, val); - store_reg(s, 14, tmp); - } - offset = (((int32_t)insn << 8) >> 8); - val += (offset << 2) + 4; - gen_jmp(s, val); - } - break; - case 0xc: - case 0xd: - case 0xe: - /* Coprocessor. */ - if (disas_coproc_insn(env, s, insn)) - goto illegal_op; - break; - case 0xf: - /* swi */ - gen_set_pc_im(s->pc); - s->is_jmp = DISAS_SWI; - break; - default: - illegal_op: - gen_set_condexec(s); - gen_set_pc_im(s->pc - 4); - gen_exception(EXCP_UDEF); - s->is_jmp = DISAS_JUMP; - break; - } - } -} - -/* Return true if this is a Thumb-2 logical op. */ -static int -thumb2_logic_op(int op) -{ - return (op < 8); -} - -/* Generate code for a Thumb-2 data processing operation. If CONDS is nonzero - then set condition code flags based on the result of the operation. - If SHIFTER_OUT is nonzero then set the carry flag for logical operations - to the high bit of T1. - Returns zero if the opcode is valid. */ - -static int -gen_thumb2_data_op(DisasContext *s, int op, int conds, uint32_t shifter_out, TCGv t0, TCGv t1) -{ - int logic_cc; - - logic_cc = 0; - switch (op) { - case 0: /* and */ - tcg_gen_and_i32(t0, t0, t1); - logic_cc = conds; - break; - case 1: /* bic */ - tcg_gen_andc_i32(t0, t0, t1); - logic_cc = conds; - break; - case 2: /* orr */ - tcg_gen_or_i32(t0, t0, t1); - logic_cc = conds; - break; - case 3: /* orn */ - tcg_gen_not_i32(t1, t1); - tcg_gen_or_i32(t0, t0, t1); - logic_cc = conds; - break; - case 4: /* eor */ - tcg_gen_xor_i32(t0, t0, t1); - logic_cc = conds; - break; - case 8: /* add */ - if (conds) - gen_helper_add_cc(t0, t0, t1); - else - tcg_gen_add_i32(t0, t0, t1); - break; - case 10: /* adc */ - if (conds) - gen_helper_adc_cc(t0, t0, t1); - else - gen_adc(t0, t1); - break; - case 11: /* sbc */ - if (conds) - gen_helper_sbc_cc(t0, t0, t1); - else - gen_sub_carry(t0, t0, t1); - break; - case 13: /* sub */ - if (conds) - gen_helper_sub_cc(t0, t0, t1); - else - tcg_gen_sub_i32(t0, t0, t1); - break; - case 14: /* rsb */ - if (conds) - gen_helper_sub_cc(t0, t1, t0); - else - tcg_gen_sub_i32(t0, t1, t0); - break; - default: /* 5, 6, 7, 9, 12, 15. */ - return 1; - } - if (logic_cc) { - gen_logic_CC(t0); - if (shifter_out) - gen_set_CF_bit31(t1); - } - return 0; -} - -/* Translate a 32-bit thumb instruction. Returns nonzero if the instruction - is not legal. */ -static int disas_thumb2_insn(CPUState *env, DisasContext *s, uint16_t insn_hw1) -{ - uint32_t insn, imm, shift, offset; - uint32_t rd, rn, rm, rs; - TCGv tmp; - TCGv tmp2; - TCGv tmp3; - TCGv addr; - TCGv_i64 tmp64; - int op; - int shiftop; - int conds; - int logic_cc; - - if (!(arm_feature(env, ARM_FEATURE_THUMB2) - || arm_feature (env, ARM_FEATURE_M))) { - /* Thumb-1 cores may need to treat bl and blx as a pair of - 16-bit instructions to get correct prefetch abort behavior. */ - insn = insn_hw1; - if ((insn & (1 << 12)) == 0) { - /* Second half of blx. */ - offset = ((insn & 0x7ff) << 1); - tmp = load_reg(s, 14); - tcg_gen_addi_i32(tmp, tmp, offset); - tcg_gen_andi_i32(tmp, tmp, 0xfffffffc); - - tmp2 = new_tmp(); - tcg_gen_movi_i32(tmp2, s->pc | 1); - store_reg(s, 14, tmp2); - gen_bx(s, tmp); - return 0; - } - if (insn & (1 << 11)) { - /* Second half of bl. */ - offset = ((insn & 0x7ff) << 1) | 1; - tmp = load_reg(s, 14); - tcg_gen_addi_i32(tmp, tmp, offset); - - tmp2 = new_tmp(); - tcg_gen_movi_i32(tmp2, s->pc | 1); - store_reg(s, 14, tmp2); - gen_bx(s, tmp); - return 0; - } - if ((s->pc & ~TARGET_PAGE_MASK) == 0) { - /* Instruction spans a page boundary. Implement it as two - 16-bit instructions in case the second half causes an - prefetch abort. */ - offset = ((int32_t)insn << 21) >> 9; - tcg_gen_movi_i32(cpu_R[14], s->pc + 2 + offset); - return 0; - } - /* Fall through to 32-bit decode. */ - } - - insn = lduw_code(s->pc); - s->pc += 2; - insn |= (uint32_t)insn_hw1 << 16; - - if ((insn & 0xf800e800) != 0xf000e800) { - ARCH(6T2); - } - - rn = (insn >> 16) & 0xf; - rs = (insn >> 12) & 0xf; - rd = (insn >> 8) & 0xf; - rm = insn & 0xf; - switch ((insn >> 25) & 0xf) { - case 0: case 1: case 2: case 3: - /* 16-bit instructions. Should never happen. */ - abort(); - case 4: - if (insn & (1 << 22)) { - /* Other load/store, table branch. */ - if (insn & 0x01200000) { - /* Load/store doubleword. */ - if (rn == 15) { - addr = new_tmp(); - tcg_gen_movi_i32(addr, s->pc & ~3); - } else { - addr = load_reg(s, rn); - } - offset = (insn & 0xff) * 4; - if ((insn & (1 << 23)) == 0) - offset = -offset; - if (insn & (1 << 24)) { - tcg_gen_addi_i32(addr, addr, offset); - offset = 0; - } - if (insn & (1 << 20)) { - /* ldrd */ - tmp = gen_ld32(addr, IS_USER(s)); - store_reg(s, rs, tmp); - tcg_gen_addi_i32(addr, addr, 4); - tmp = gen_ld32(addr, IS_USER(s)); - store_reg(s, rd, tmp); - } else { - /* strd */ - tmp = load_reg(s, rs); - gen_st32(tmp, addr, IS_USER(s)); - tcg_gen_addi_i32(addr, addr, 4); - tmp = load_reg(s, rd); - gen_st32(tmp, addr, IS_USER(s)); - } - if (insn & (1 << 21)) { - /* Base writeback. */ - if (rn == 15) - goto illegal_op; - tcg_gen_addi_i32(addr, addr, offset - 4); - store_reg(s, rn, addr); - } else { - dead_tmp(addr); - } - } else if ((insn & (1 << 23)) == 0) { - /* Load/store exclusive word. */ - addr = tcg_temp_local_new(); - load_reg_var(s, addr, rn); - tcg_gen_addi_i32(addr, addr, (insn & 0xff) << 2); - if (insn & (1 << 20)) { - gen_load_exclusive(s, rs, 15, addr, 2); - } else { - gen_store_exclusive(s, rd, rs, 15, addr, 2); - } - tcg_temp_free(addr); - } else if ((insn & (1 << 6)) == 0) { - /* Table Branch. */ - if (rn == 15) { - addr = new_tmp(); - tcg_gen_movi_i32(addr, s->pc); - } else { - addr = load_reg(s, rn); - } - tmp = load_reg(s, rm); - tcg_gen_add_i32(addr, addr, tmp); - if (insn & (1 << 4)) { - /* tbh */ - tcg_gen_add_i32(addr, addr, tmp); - dead_tmp(tmp); - tmp = gen_ld16u(addr, IS_USER(s)); - } else { /* tbb */ - dead_tmp(tmp); - tmp = gen_ld8u(addr, IS_USER(s)); - } - dead_tmp(addr); - tcg_gen_shli_i32(tmp, tmp, 1); - tcg_gen_addi_i32(tmp, tmp, s->pc); - store_reg(s, 15, tmp); - } else { - /* Load/store exclusive byte/halfword/doubleword. */ - ARCH(7); - op = (insn >> 4) & 0x3; - if (op == 2) { - goto illegal_op; - } - addr = tcg_temp_local_new(); - load_reg_var(s, addr, rn); - if (insn & (1 << 20)) { - gen_load_exclusive(s, rs, rd, addr, op); - } else { - gen_store_exclusive(s, rm, rs, rd, addr, op); - } - tcg_temp_free(addr); - } - } else { - /* Load/store multiple, RFE, SRS. */ - if (((insn >> 23) & 1) == ((insn >> 24) & 1)) { - /* Not available in user mode. */ - if (IS_USER(s)) - goto illegal_op; - if (insn & (1 << 20)) { - /* rfe */ - addr = load_reg(s, rn); - if ((insn & (1 << 24)) == 0) - tcg_gen_addi_i32(addr, addr, -8); - /* Load PC into tmp and CPSR into tmp2. */ - tmp = gen_ld32(addr, 0); - tcg_gen_addi_i32(addr, addr, 4); - tmp2 = gen_ld32(addr, 0); - if (insn & (1 << 21)) { - /* Base writeback. */ - if (insn & (1 << 24)) { - tcg_gen_addi_i32(addr, addr, 4); - } else { - tcg_gen_addi_i32(addr, addr, -4); - } - store_reg(s, rn, addr); - } else { - dead_tmp(addr); - } - gen_rfe(s, tmp, tmp2); - } else { - /* srs */ - op = (insn & 0x1f); - if (op == (env->uncached_cpsr & CPSR_M)) { - addr = load_reg(s, 13); - } else { - addr = new_tmp(); - tmp = tcg_const_i32(op); - gen_helper_get_r13_banked(addr, cpu_env, tmp); - tcg_temp_free_i32(tmp); - } - if ((insn & (1 << 24)) == 0) { - tcg_gen_addi_i32(addr, addr, -8); - } - tmp = load_reg(s, 14); - gen_st32(tmp, addr, 0); - tcg_gen_addi_i32(addr, addr, 4); - tmp = new_tmp(); - gen_helper_cpsr_read(tmp); - gen_st32(tmp, addr, 0); - if (insn & (1 << 21)) { - if ((insn & (1 << 24)) == 0) { - tcg_gen_addi_i32(addr, addr, -4); - } else { - tcg_gen_addi_i32(addr, addr, 4); - } - if (op == (env->uncached_cpsr & CPSR_M)) { - store_reg(s, 13, addr); - } else { - tmp = tcg_const_i32(op); - gen_helper_set_r13_banked(cpu_env, tmp, addr); - tcg_temp_free_i32(tmp); - } - } else { - dead_tmp(addr); - } - } - } else { - int i; - /* Load/store multiple. */ - addr = load_reg(s, rn); - offset = 0; - for (i = 0; i < 16; i++) { - if (insn & (1 << i)) - offset += 4; - } - if (insn & (1 << 24)) { - tcg_gen_addi_i32(addr, addr, -offset); - } - - for (i = 0; i < 16; i++) { - if ((insn & (1 << i)) == 0) - continue; - if (insn & (1 << 20)) { - /* Load. */ - tmp = gen_ld32(addr, IS_USER(s)); - if (i == 15) { - gen_bx(s, tmp); - } else { - store_reg(s, i, tmp); - } - } else { - /* Store. */ - tmp = load_reg(s, i); - gen_st32(tmp, addr, IS_USER(s)); - } - tcg_gen_addi_i32(addr, addr, 4); - } - if (insn & (1 << 21)) { - /* Base register writeback. */ - if (insn & (1 << 24)) { - tcg_gen_addi_i32(addr, addr, -offset); - } - /* Fault if writeback register is in register list. */ - if (insn & (1 << rn)) - goto illegal_op; - store_reg(s, rn, addr); - } else { - dead_tmp(addr); - } - } - } - break; - case 5: /* Data processing register constant shift. */ - if (rn == 15) { - tmp = new_tmp(); - tcg_gen_movi_i32(tmp, 0); - } else { - tmp = load_reg(s, rn); - } - tmp2 = load_reg(s, rm); - op = (insn >> 21) & 0xf; - shiftop = (insn >> 4) & 3; - shift = ((insn >> 6) & 3) | ((insn >> 10) & 0x1c); - conds = (insn & (1 << 20)) != 0; - logic_cc = (conds && thumb2_logic_op(op)); - gen_arm_shift_im(tmp2, shiftop, shift, logic_cc); - if (gen_thumb2_data_op(s, op, conds, 0, tmp, tmp2)) - goto illegal_op; - dead_tmp(tmp2); - if (rd != 15) { - store_reg(s, rd, tmp); - } else { - dead_tmp(tmp); - } - break; - case 13: /* Misc data processing. */ - op = ((insn >> 22) & 6) | ((insn >> 7) & 1); - if (op < 4 && (insn & 0xf000) != 0xf000) - goto illegal_op; - switch (op) { - case 0: /* Register controlled shift. */ - tmp = load_reg(s, rn); - tmp2 = load_reg(s, rm); - if ((insn & 0x70) != 0) - goto illegal_op; - op = (insn >> 21) & 3; - logic_cc = (insn & (1 << 20)) != 0; - gen_arm_shift_reg(tmp, op, tmp2, logic_cc); - if (logic_cc) - gen_logic_CC(tmp); - store_reg_bx(env, s, rd, tmp); - break; - case 1: /* Sign/zero extend. */ - tmp = load_reg(s, rm); - shift = (insn >> 4) & 3; - /* ??? In many cases it's not neccessary to do a - rotate, a shift is sufficient. */ - if (shift != 0) - tcg_gen_rotri_i32(tmp, tmp, shift * 8); - op = (insn >> 20) & 7; - switch (op) { - case 0: gen_sxth(tmp); break; - case 1: gen_uxth(tmp); break; - case 2: gen_sxtb16(tmp); break; - case 3: gen_uxtb16(tmp); break; - case 4: gen_sxtb(tmp); break; - case 5: gen_uxtb(tmp); break; - default: goto illegal_op; - } - if (rn != 15) { - tmp2 = load_reg(s, rn); - if ((op >> 1) == 1) { - gen_add16(tmp, tmp2); - } else { - tcg_gen_add_i32(tmp, tmp, tmp2); - dead_tmp(tmp2); - } - } - store_reg(s, rd, tmp); - break; - case 2: /* SIMD add/subtract. */ - op = (insn >> 20) & 7; - shift = (insn >> 4) & 7; - if ((op & 3) == 3 || (shift & 3) == 3) - goto illegal_op; - tmp = load_reg(s, rn); - tmp2 = load_reg(s, rm); - gen_thumb2_parallel_addsub(op, shift, tmp, tmp2); - dead_tmp(tmp2); - store_reg(s, rd, tmp); - break; - case 3: /* Other data processing. */ - op = ((insn >> 17) & 0x38) | ((insn >> 4) & 7); - if (op < 4) { - /* Saturating add/subtract. */ - tmp = load_reg(s, rn); - tmp2 = load_reg(s, rm); - if (op & 2) - gen_helper_double_saturate(tmp, tmp); - if (op & 1) - gen_helper_sub_saturate(tmp, tmp2, tmp); - else - gen_helper_add_saturate(tmp, tmp, tmp2); - dead_tmp(tmp2); - } else { - tmp = load_reg(s, rn); - switch (op) { - case 0x0a: /* rbit */ - gen_helper_rbit(tmp, tmp); - break; - case 0x08: /* rev */ - tcg_gen_bswap32_i32(tmp, tmp); - break; - case 0x09: /* rev16 */ - gen_rev16(tmp); - break; - case 0x0b: /* revsh */ - gen_revsh(tmp); - break; - case 0x10: /* sel */ - tmp2 = load_reg(s, rm); - tmp3 = new_tmp(); - tcg_gen_ld_i32(tmp3, cpu_env, offsetof(CPUState, GE)); - gen_helper_sel_flags(tmp, tmp3, tmp, tmp2); - dead_tmp(tmp3); - dead_tmp(tmp2); - break; - case 0x18: /* clz */ - gen_helper_clz(tmp, tmp); - break; - default: - goto illegal_op; - } - } - store_reg(s, rd, tmp); - break; - case 4: case 5: /* 32-bit multiply. Sum of absolute differences. */ - op = (insn >> 4) & 0xf; - tmp = load_reg(s, rn); - tmp2 = load_reg(s, rm); - switch ((insn >> 20) & 7) { - case 0: /* 32 x 32 -> 32 */ - tcg_gen_mul_i32(tmp, tmp, tmp2); - dead_tmp(tmp2); - if (rs != 15) { - tmp2 = load_reg(s, rs); - if (op) - tcg_gen_sub_i32(tmp, tmp2, tmp); - else - tcg_gen_add_i32(tmp, tmp, tmp2); - dead_tmp(tmp2); - } - break; - case 1: /* 16 x 16 -> 32 */ - gen_mulxy(tmp, tmp2, op & 2, op & 1); - dead_tmp(tmp2); - if (rs != 15) { - tmp2 = load_reg(s, rs); - gen_helper_add_setq(tmp, tmp, tmp2); - dead_tmp(tmp2); - } - break; - case 2: /* Dual multiply add. */ - case 4: /* Dual multiply subtract. */ - if (op) - gen_swap_half(tmp2); - gen_smul_dual(tmp, tmp2); - /* This addition cannot overflow. */ - if (insn & (1 << 22)) { - tcg_gen_sub_i32(tmp, tmp, tmp2); - } else { - tcg_gen_add_i32(tmp, tmp, tmp2); - } - dead_tmp(tmp2); - if (rs != 15) - { - tmp2 = load_reg(s, rs); - gen_helper_add_setq(tmp, tmp, tmp2); - dead_tmp(tmp2); - } - break; - case 3: /* 32 * 16 -> 32msb */ - if (op) - tcg_gen_sari_i32(tmp2, tmp2, 16); - else - gen_sxth(tmp2); - tmp64 = gen_muls_i64_i32(tmp, tmp2); - tcg_gen_shri_i64(tmp64, tmp64, 16); - tmp = new_tmp(); - tcg_gen_trunc_i64_i32(tmp, tmp64); - tcg_temp_free_i64(tmp64); - if (rs != 15) - { - tmp2 = load_reg(s, rs); - gen_helper_add_setq(tmp, tmp, tmp2); - dead_tmp(tmp2); - } - break; - case 5: case 6: /* 32 * 32 -> 32msb */ - gen_imull(tmp, tmp2); - if (insn & (1 << 5)) { - gen_roundqd(tmp, tmp2); - dead_tmp(tmp2); - } else { - dead_tmp(tmp); - tmp = tmp2; - } - if (rs != 15) { - tmp2 = load_reg(s, rs); - if (insn & (1 << 21)) { - tcg_gen_add_i32(tmp, tmp, tmp2); - } else { - tcg_gen_sub_i32(tmp, tmp2, tmp); - } - dead_tmp(tmp2); - } - break; - case 7: /* Unsigned sum of absolute differences. */ - gen_helper_usad8(tmp, tmp, tmp2); - dead_tmp(tmp2); - if (rs != 15) { - tmp2 = load_reg(s, rs); - tcg_gen_add_i32(tmp, tmp, tmp2); - dead_tmp(tmp2); - } - break; - } - store_reg(s, rd, tmp); - break; - case 6: case 7: /* 64-bit multiply, Divide. */ - op = ((insn >> 4) & 0xf) | ((insn >> 16) & 0x70); - tmp = load_reg(s, rn); - tmp2 = load_reg(s, rm); - if ((op & 0x50) == 0x10) { - /* sdiv, udiv */ - if (!arm_feature(env, ARM_FEATURE_DIV)) - goto illegal_op; - if (op & 0x20) - gen_helper_udiv(tmp, tmp, tmp2); - else - gen_helper_sdiv(tmp, tmp, tmp2); - dead_tmp(tmp2); - store_reg(s, rd, tmp); - } else if ((op & 0xe) == 0xc) { - /* Dual multiply accumulate long. */ - if (op & 1) - gen_swap_half(tmp2); - gen_smul_dual(tmp, tmp2); - if (op & 0x10) { - tcg_gen_sub_i32(tmp, tmp, tmp2); - } else { - tcg_gen_add_i32(tmp, tmp, tmp2); - } - dead_tmp(tmp2); - /* BUGFIX */ - tmp64 = tcg_temp_new_i64(); - tcg_gen_ext_i32_i64(tmp64, tmp); - dead_tmp(tmp); - gen_addq(s, tmp64, rs, rd); - gen_storeq_reg(s, rs, rd, tmp64); - tcg_temp_free_i64(tmp64); - } else { - if (op & 0x20) { - /* Unsigned 64-bit multiply */ - tmp64 = gen_mulu_i64_i32(tmp, tmp2); - } else { - if (op & 8) { - /* smlalxy */ - gen_mulxy(tmp, tmp2, op & 2, op & 1); - dead_tmp(tmp2); - tmp64 = tcg_temp_new_i64(); - tcg_gen_ext_i32_i64(tmp64, tmp); - dead_tmp(tmp); - } else { - /* Signed 64-bit multiply */ - tmp64 = gen_muls_i64_i32(tmp, tmp2); - } - } - if (op & 4) { - /* umaal */ - gen_addq_lo(s, tmp64, rs); - gen_addq_lo(s, tmp64, rd); - } else if (op & 0x40) { - /* 64-bit accumulate. */ - gen_addq(s, tmp64, rs, rd); - } - gen_storeq_reg(s, rs, rd, tmp64); - tcg_temp_free_i64(tmp64); - } - break; - } - break; - case 6: case 7: case 14: case 15: - /* Coprocessor. */ - if (((insn >> 24) & 3) == 3) { - /* Translate into the equivalent ARM encoding. */ - insn = (insn & 0xe2ffffff) | ((insn & (1 << 28)) >> 4); - if (disas_neon_data_insn(env, s, insn)) - goto illegal_op; - } else { - if (insn & (1 << 28)) - goto illegal_op; - if (disas_coproc_insn (env, s, insn)) - goto illegal_op; - } - break; - case 8: case 9: case 10: case 11: - if (insn & (1 << 15)) { - /* Branches, misc control. */ - if (insn & 0x5000) { - /* Unconditional branch. */ - /* signextend(hw1[10:0]) -> offset[:12]. */ - offset = ((int32_t)insn << 5) >> 9 & ~(int32_t)0xfff; - /* hw1[10:0] -> offset[11:1]. */ - offset |= (insn & 0x7ff) << 1; - /* (~hw2[13, 11] ^ offset[24]) -> offset[23,22] - offset[24:22] already have the same value because of the - sign extension above. */ - offset ^= ((~insn) & (1 << 13)) << 10; - offset ^= ((~insn) & (1 << 11)) << 11; - - if (insn & (1 << 14)) { - /* Branch and link. */ - tcg_gen_movi_i32(cpu_R[14], s->pc | 1); - } - - offset += s->pc; - if (insn & (1 << 12)) { - /* b/bl */ - gen_jmp(s, offset); - } else { - /* blx */ - offset &= ~(uint32_t)2; - gen_bx_im(s, offset); - } - } else if (((insn >> 23) & 7) == 7) { - /* Misc control */ - if (insn & (1 << 13)) - goto illegal_op; - - if (insn & (1 << 26)) { - /* Secure monitor call (v6Z) */ - goto illegal_op; /* not implemented. */ - } else { - op = (insn >> 20) & 7; - switch (op) { - case 0: /* msr cpsr. */ - if (IS_M(env)) { - tmp = load_reg(s, rn); - addr = tcg_const_i32(insn & 0xff); - gen_helper_v7m_msr(cpu_env, addr, tmp); - tcg_temp_free_i32(addr); - dead_tmp(tmp); - gen_lookup_tb(s); - break; - } - /* fall through */ - case 1: /* msr spsr. */ - if (IS_M(env)) - goto illegal_op; - tmp = load_reg(s, rn); - if (gen_set_psr(s, - msr_mask(env, s, (insn >> 8) & 0xf, op == 1), - op == 1, tmp)) - goto illegal_op; - break; - case 2: /* cps, nop-hint. */ - if (((insn >> 8) & 7) == 0) { - gen_nop_hint(s, insn & 0xff); - } - /* Implemented as NOP in user mode. */ - if (IS_USER(s)) - break; - offset = 0; - imm = 0; - if (insn & (1 << 10)) { - if (insn & (1 << 7)) - offset |= CPSR_A; - if (insn & (1 << 6)) - offset |= CPSR_I; - if (insn & (1 << 5)) - offset |= CPSR_F; - if (insn & (1 << 9)) - imm = CPSR_A | CPSR_I | CPSR_F; - } - if (insn & (1 << 8)) { - offset |= 0x1f; - imm |= (insn & 0x1f); - } - if (offset) { - gen_set_psr_im(s, offset, 0, imm); - } - break; - case 3: /* Special control operations. */ - ARCH(7); - op = (insn >> 4) & 0xf; - switch (op) { - case 2: /* clrex */ - gen_clrex(s); - break; - case 4: /* dsb */ - case 5: /* dmb */ - case 6: /* isb */ - /* These execute as NOPs. */ - break; - default: - goto illegal_op; - } - break; - case 4: /* bxj */ - /* Trivial implementation equivalent to bx. */ - tmp = load_reg(s, rn); - gen_bx(s, tmp); - break; - case 5: /* Exception return. */ - /* Unpredictable in user mode. */ - goto illegal_op; - case 6: /* mrs cpsr. */ - tmp = new_tmp(); - if (IS_M(env)) { - addr = tcg_const_i32(insn & 0xff); - gen_helper_v7m_mrs(tmp, cpu_env, addr); - tcg_temp_free_i32(addr); - } else { - gen_helper_cpsr_read(tmp); - } - store_reg(s, rd, tmp); - break; - case 7: /* mrs spsr. */ - /* Not accessible in user mode. */ - if (IS_USER(s) || IS_M(env)) - goto illegal_op; - tmp = load_cpu_field(spsr); - store_reg(s, rd, tmp); - break; - } - } - } else { - /* Conditional branch. */ - op = (insn >> 22) & 0xf; - /* Generate a conditional jump to next instruction. */ - s->condlabel = gen_new_label(); - gen_test_cc(op ^ 1, s->condlabel); - s->condjmp = 1; - - /* offset[11:1] = insn[10:0] */ - offset = (insn & 0x7ff) << 1; - /* offset[17:12] = insn[21:16]. */ - offset |= (insn & 0x003f0000) >> 4; - /* offset[31:20] = insn[26]. */ - offset |= ((int32_t)((insn << 5) & 0x80000000)) >> 11; - /* offset[18] = insn[13]. */ - offset |= (insn & (1 << 13)) << 5; - /* offset[19] = insn[11]. */ - offset |= (insn & (1 << 11)) << 8; - - /* jump to the offset */ - gen_jmp(s, s->pc + offset); - } - } else { - /* Data processing immediate. */ - if (insn & (1 << 25)) { - if (insn & (1 << 24)) { - if (insn & (1 << 20)) - goto illegal_op; - /* Bitfield/Saturate. */ - op = (insn >> 21) & 7; - imm = insn & 0x1f; - shift = ((insn >> 6) & 3) | ((insn >> 10) & 0x1c); - if (rn == 15) { - tmp = new_tmp(); - tcg_gen_movi_i32(tmp, 0); - } else { - tmp = load_reg(s, rn); - } - switch (op) { - case 2: /* Signed bitfield extract. */ - imm++; - if (shift + imm > 32) - goto illegal_op; - if (imm < 32) - gen_sbfx(tmp, shift, imm); - break; - case 6: /* Unsigned bitfield extract. */ - imm++; - if (shift + imm > 32) - goto illegal_op; - if (imm < 32) - gen_ubfx(tmp, shift, (1u << imm) - 1); - break; - case 3: /* Bitfield insert/clear. */ - if (imm < shift) - goto illegal_op; - imm = imm + 1 - shift; - if (imm != 32) { - tmp2 = load_reg(s, rd); - gen_bfi(tmp, tmp2, tmp, shift, (1u << imm) - 1); - dead_tmp(tmp2); - } - break; - case 7: - goto illegal_op; - default: /* Saturate. */ - if (shift) { - if (op & 1) - tcg_gen_sari_i32(tmp, tmp, shift); - else - tcg_gen_shli_i32(tmp, tmp, shift); - } - tmp2 = tcg_const_i32(imm); - if (op & 4) { - /* Unsigned. */ - if ((op & 1) && shift == 0) - gen_helper_usat16(tmp, tmp, tmp2); - else - gen_helper_usat(tmp, tmp, tmp2); - } else { - /* Signed. */ - if ((op & 1) && shift == 0) - gen_helper_ssat16(tmp, tmp, tmp2); - else - gen_helper_ssat(tmp, tmp, tmp2); - } - tcg_temp_free_i32(tmp2); - break; - } - store_reg(s, rd, tmp); - } else { - imm = ((insn & 0x04000000) >> 15) - | ((insn & 0x7000) >> 4) | (insn & 0xff); - if (insn & (1 << 22)) { - /* 16-bit immediate. */ - imm |= (insn >> 4) & 0xf000; - if (insn & (1 << 23)) { - /* movt */ - tmp = load_reg(s, rd); - tcg_gen_ext16u_i32(tmp, tmp); - tcg_gen_ori_i32(tmp, tmp, imm << 16); - } else { - /* movw */ - tmp = new_tmp(); - tcg_gen_movi_i32(tmp, imm); - } - } else { - /* Add/sub 12-bit immediate. */ - if (rn == 15) { - offset = s->pc & ~(uint32_t)3; - if (insn & (1 << 23)) - offset -= imm; - else - offset += imm; - tmp = new_tmp(); - tcg_gen_movi_i32(tmp, offset); - } else { - tmp = load_reg(s, rn); - if (insn & (1 << 23)) - tcg_gen_subi_i32(tmp, tmp, imm); - else - tcg_gen_addi_i32(tmp, tmp, imm); - } - } - store_reg(s, rd, tmp); - } - } else { - int shifter_out = 0; - /* modified 12-bit immediate. */ - shift = ((insn & 0x04000000) >> 23) | ((insn & 0x7000) >> 12); - imm = (insn & 0xff); - switch (shift) { - case 0: /* XY */ - /* Nothing to do. */ - break; - case 1: /* 00XY00XY */ - imm |= imm << 16; - break; - case 2: /* XY00XY00 */ - imm |= imm << 16; - imm <<= 8; - break; - case 3: /* XYXYXYXY */ - imm |= imm << 16; - imm |= imm << 8; - break; - default: /* Rotated constant. */ - shift = (shift << 1) | (imm >> 7); - imm |= 0x80; - imm = imm << (32 - shift); - shifter_out = 1; - break; - } - tmp2 = new_tmp(); - tcg_gen_movi_i32(tmp2, imm); - rn = (insn >> 16) & 0xf; - if (rn == 15) { - tmp = new_tmp(); - tcg_gen_movi_i32(tmp, 0); - } else { - tmp = load_reg(s, rn); - } - op = (insn >> 21) & 0xf; - if (gen_thumb2_data_op(s, op, (insn & (1 << 20)) != 0, - shifter_out, tmp, tmp2)) - goto illegal_op; - dead_tmp(tmp2); - rd = (insn >> 8) & 0xf; - if (rd != 15) { - store_reg(s, rd, tmp); - } else { - dead_tmp(tmp); - } - } - } - break; - case 12: /* Load/store single data item. */ - { - int postinc = 0; - int writeback = 0; - int user; - if ((insn & 0x01100000) == 0x01000000) { - if (disas_neon_ls_insn(env, s, insn)) - goto illegal_op; - break; - } - user = IS_USER(s); - if (rn == 15) { - addr = new_tmp(); - /* PC relative. */ - /* s->pc has already been incremented by 4. */ - imm = s->pc & 0xfffffffc; - if (insn & (1 << 23)) - imm += insn & 0xfff; - else - imm -= insn & 0xfff; - tcg_gen_movi_i32(addr, imm); - } else { - addr = load_reg(s, rn); - if (insn & (1 << 23)) { - /* Positive offset. */ - imm = insn & 0xfff; - tcg_gen_addi_i32(addr, addr, imm); - } else { - op = (insn >> 8) & 7; - imm = insn & 0xff; - switch (op) { - case 0: case 8: /* Shifted Register. */ - shift = (insn >> 4) & 0xf; - if (shift > 3) - goto illegal_op; - tmp = load_reg(s, rm); - if (shift) - tcg_gen_shli_i32(tmp, tmp, shift); - tcg_gen_add_i32(addr, addr, tmp); - dead_tmp(tmp); - break; - case 4: /* Negative offset. */ - tcg_gen_addi_i32(addr, addr, -imm); - break; - case 6: /* User privilege. */ - tcg_gen_addi_i32(addr, addr, imm); - user = 1; - break; - case 1: /* Post-decrement. */ - imm = -imm; - /* Fall through. */ - case 3: /* Post-increment. */ - postinc = 1; - writeback = 1; - break; - case 5: /* Pre-decrement. */ - imm = -imm; - /* Fall through. */ - case 7: /* Pre-increment. */ - tcg_gen_addi_i32(addr, addr, imm); - writeback = 1; - break; - default: - goto illegal_op; - } - } - } - op = ((insn >> 21) & 3) | ((insn >> 22) & 4); - if (insn & (1 << 20)) { - /* Load. */ - if (rs == 15 && op != 2) { - if (op & 2) - goto illegal_op; - /* Memory hint. Implemented as NOP. */ - } else { - switch (op) { - case 0: tmp = gen_ld8u(addr, user); break; - case 4: tmp = gen_ld8s(addr, user); break; - case 1: tmp = gen_ld16u(addr, user); break; - case 5: tmp = gen_ld16s(addr, user); break; - case 2: tmp = gen_ld32(addr, user); break; - default: goto illegal_op; - } - if (rs == 15) { - gen_bx(s, tmp); - } else { - store_reg(s, rs, tmp); - } - } - } else { - /* Store. */ - if (rs == 15) - goto illegal_op; - tmp = load_reg(s, rs); - switch (op) { - case 0: gen_st8(tmp, addr, user); break; - case 1: gen_st16(tmp, addr, user); break; - case 2: gen_st32(tmp, addr, user); break; - default: goto illegal_op; - } - } - if (postinc) - tcg_gen_addi_i32(addr, addr, imm); - if (writeback) { - store_reg(s, rn, addr); - } else { - dead_tmp(addr); - } - } - break; - default: - goto illegal_op; - } - return 0; -illegal_op: - return 1; -} - -static void disas_thumb_insn(CPUState *env, DisasContext *s) -{ - uint32_t val, insn, op, rm, rn, rd, shift, cond; - int32_t offset; - int i; - TCGv tmp; - TCGv tmp2; - TCGv addr; - - if (s->condexec_mask) { - cond = s->condexec_cond; - s->condlabel = gen_new_label(); - gen_test_cc(cond ^ 1, s->condlabel); - s->condjmp = 1; - } - - insn = lduw_code(s->pc); - s->pc += 2; - - switch (insn >> 12) { - case 0: case 1: - - rd = insn & 7; - op = (insn >> 11) & 3; - if (op == 3) { - /* add/subtract */ - rn = (insn >> 3) & 7; - tmp = load_reg(s, rn); - if (insn & (1 << 10)) { - /* immediate */ - tmp2 = new_tmp(); - tcg_gen_movi_i32(tmp2, (insn >> 6) & 7); - } else { - /* reg */ - rm = (insn >> 6) & 7; - tmp2 = load_reg(s, rm); - } - if (insn & (1 << 9)) { - if (s->condexec_mask) - tcg_gen_sub_i32(tmp, tmp, tmp2); - else - gen_helper_sub_cc(tmp, tmp, tmp2); - } else { - if (s->condexec_mask) - tcg_gen_add_i32(tmp, tmp, tmp2); - else - gen_helper_add_cc(tmp, tmp, tmp2); - } - dead_tmp(tmp2); - store_reg(s, rd, tmp); - } else { - /* shift immediate */ - rm = (insn >> 3) & 7; - shift = (insn >> 6) & 0x1f; - tmp = load_reg(s, rm); - gen_arm_shift_im(tmp, op, shift, s->condexec_mask == 0); - if (!s->condexec_mask) - gen_logic_CC(tmp); - store_reg(s, rd, tmp); - } - break; - case 2: case 3: - /* arithmetic large immediate */ - op = (insn >> 11) & 3; - rd = (insn >> 8) & 0x7; - if (op == 0) { /* mov */ - tmp = new_tmp(); - tcg_gen_movi_i32(tmp, insn & 0xff); - if (!s->condexec_mask) - gen_logic_CC(tmp); - store_reg(s, rd, tmp); - } else { - tmp = load_reg(s, rd); - tmp2 = new_tmp(); - tcg_gen_movi_i32(tmp2, insn & 0xff); - switch (op) { - case 1: /* cmp */ - gen_helper_sub_cc(tmp, tmp, tmp2); - dead_tmp(tmp); - dead_tmp(tmp2); - break; - case 2: /* add */ - if (s->condexec_mask) - tcg_gen_add_i32(tmp, tmp, tmp2); - else - gen_helper_add_cc(tmp, tmp, tmp2); - dead_tmp(tmp2); - store_reg(s, rd, tmp); - break; - case 3: /* sub */ - if (s->condexec_mask) - tcg_gen_sub_i32(tmp, tmp, tmp2); - else - gen_helper_sub_cc(tmp, tmp, tmp2); - dead_tmp(tmp2); - store_reg(s, rd, tmp); - break; - } - } - break; - case 4: - if (insn & (1 << 11)) { - rd = (insn >> 8) & 7; - /* load pc-relative. Bit 1 of PC is ignored. */ - val = s->pc + 2 + ((insn & 0xff) * 4); - val &= ~(uint32_t)2; - addr = new_tmp(); - tcg_gen_movi_i32(addr, val); - tmp = gen_ld32(addr, IS_USER(s)); - dead_tmp(addr); - store_reg(s, rd, tmp); - break; - } - if (insn & (1 << 10)) { - /* data processing extended or blx */ - rd = (insn & 7) | ((insn >> 4) & 8); - rm = (insn >> 3) & 0xf; - op = (insn >> 8) & 3; - switch (op) { - case 0: /* add */ - tmp = load_reg(s, rd); - tmp2 = load_reg(s, rm); - tcg_gen_add_i32(tmp, tmp, tmp2); - dead_tmp(tmp2); - store_reg(s, rd, tmp); - break; - case 1: /* cmp */ - tmp = load_reg(s, rd); - tmp2 = load_reg(s, rm); - gen_helper_sub_cc(tmp, tmp, tmp2); - dead_tmp(tmp2); - dead_tmp(tmp); - break; - case 2: /* mov/cpy */ - tmp = load_reg(s, rm); - store_reg(s, rd, tmp); - break; - case 3:/* branch [and link] exchange thumb register */ - tmp = load_reg(s, rm); - if (insn & (1 << 7)) { - val = (uint32_t)s->pc | 1; - tmp2 = new_tmp(); - tcg_gen_movi_i32(tmp2, val); - store_reg(s, 14, tmp2); - } - gen_bx(s, tmp); - break; - } - break; - } - - /* data processing register */ - rd = insn & 7; - rm = (insn >> 3) & 7; - op = (insn >> 6) & 0xf; - if (op == 2 || op == 3 || op == 4 || op == 7) { - /* the shift/rotate ops want the operands backwards */ - val = rm; - rm = rd; - rd = val; - val = 1; - } else { - val = 0; - } - - if (op == 9) { /* neg */ - tmp = new_tmp(); - tcg_gen_movi_i32(tmp, 0); - } else if (op != 0xf) { /* mvn doesn't read its first operand */ - tmp = load_reg(s, rd); - } else { - TCGV_UNUSED(tmp); - } - - tmp2 = load_reg(s, rm); - switch (op) { - case 0x0: /* and */ - tcg_gen_and_i32(tmp, tmp, tmp2); - if (!s->condexec_mask) - gen_logic_CC(tmp); - break; - case 0x1: /* eor */ - tcg_gen_xor_i32(tmp, tmp, tmp2); - if (!s->condexec_mask) - gen_logic_CC(tmp); - break; - case 0x2: /* lsl */ - if (s->condexec_mask) { - gen_helper_shl(tmp2, tmp2, tmp); - } else { - gen_helper_shl_cc(tmp2, tmp2, tmp); - gen_logic_CC(tmp2); - } - break; - case 0x3: /* lsr */ - if (s->condexec_mask) { - gen_helper_shr(tmp2, tmp2, tmp); - } else { - gen_helper_shr_cc(tmp2, tmp2, tmp); - gen_logic_CC(tmp2); - } - break; - case 0x4: /* asr */ - if (s->condexec_mask) { - gen_helper_sar(tmp2, tmp2, tmp); - } else { - gen_helper_sar_cc(tmp2, tmp2, tmp); - gen_logic_CC(tmp2); - } - break; - case 0x5: /* adc */ - if (s->condexec_mask) - gen_adc(tmp, tmp2); - else - gen_helper_adc_cc(tmp, tmp, tmp2); - break; - case 0x6: /* sbc */ - if (s->condexec_mask) - gen_sub_carry(tmp, tmp, tmp2); - else - gen_helper_sbc_cc(tmp, tmp, tmp2); - break; - case 0x7: /* ror */ - if (s->condexec_mask) { - tcg_gen_andi_i32(tmp, tmp, 0x1f); - tcg_gen_rotr_i32(tmp2, tmp2, tmp); - } else { - gen_helper_ror_cc(tmp2, tmp2, tmp); - gen_logic_CC(tmp2); - } - break; - case 0x8: /* tst */ - tcg_gen_and_i32(tmp, tmp, tmp2); - gen_logic_CC(tmp); - rd = 16; - break; - case 0x9: /* neg */ - if (s->condexec_mask) - tcg_gen_neg_i32(tmp, tmp2); - else - gen_helper_sub_cc(tmp, tmp, tmp2); - break; - case 0xa: /* cmp */ - gen_helper_sub_cc(tmp, tmp, tmp2); - rd = 16; - break; - case 0xb: /* cmn */ - gen_helper_add_cc(tmp, tmp, tmp2); - rd = 16; - break; - case 0xc: /* orr */ - tcg_gen_or_i32(tmp, tmp, tmp2); - if (!s->condexec_mask) - gen_logic_CC(tmp); - break; - case 0xd: /* mul */ - tcg_gen_mul_i32(tmp, tmp, tmp2); - if (!s->condexec_mask) - gen_logic_CC(tmp); - break; - case 0xe: /* bic */ - tcg_gen_andc_i32(tmp, tmp, tmp2); - if (!s->condexec_mask) - gen_logic_CC(tmp); - break; - case 0xf: /* mvn */ - tcg_gen_not_i32(tmp2, tmp2); - if (!s->condexec_mask) - gen_logic_CC(tmp2); - val = 1; - rm = rd; - break; - } - if (rd != 16) { - if (val) { - store_reg(s, rm, tmp2); - if (op != 0xf) - dead_tmp(tmp); - } else { - store_reg(s, rd, tmp); - dead_tmp(tmp2); - } - } else { - dead_tmp(tmp); - dead_tmp(tmp2); - } - break; - - case 5: - /* load/store register offset. */ - rd = insn & 7; - rn = (insn >> 3) & 7; - rm = (insn >> 6) & 7; - op = (insn >> 9) & 7; - addr = load_reg(s, rn); - tmp = load_reg(s, rm); - tcg_gen_add_i32(addr, addr, tmp); - dead_tmp(tmp); - - if (op < 3) /* store */ - tmp = load_reg(s, rd); - - switch (op) { - case 0: /* str */ - gen_st32(tmp, addr, IS_USER(s)); - break; - case 1: /* strh */ - gen_st16(tmp, addr, IS_USER(s)); - break; - case 2: /* strb */ - gen_st8(tmp, addr, IS_USER(s)); - break; - case 3: /* ldrsb */ - tmp = gen_ld8s(addr, IS_USER(s)); - break; - case 4: /* ldr */ - tmp = gen_ld32(addr, IS_USER(s)); - break; - case 5: /* ldrh */ - tmp = gen_ld16u(addr, IS_USER(s)); - break; - case 6: /* ldrb */ - tmp = gen_ld8u(addr, IS_USER(s)); - break; - case 7: /* ldrsh */ - tmp = gen_ld16s(addr, IS_USER(s)); - break; - } - if (op >= 3) /* load */ - store_reg(s, rd, tmp); - dead_tmp(addr); - break; - - case 6: - /* load/store word immediate offset */ - rd = insn & 7; - rn = (insn >> 3) & 7; - addr = load_reg(s, rn); - val = (insn >> 4) & 0x7c; - tcg_gen_addi_i32(addr, addr, val); - - if (insn & (1 << 11)) { - /* load */ - tmp = gen_ld32(addr, IS_USER(s)); - store_reg(s, rd, tmp); - } else { - /* store */ - tmp = load_reg(s, rd); - gen_st32(tmp, addr, IS_USER(s)); - } - dead_tmp(addr); - break; - - case 7: - /* load/store byte immediate offset */ - rd = insn & 7; - rn = (insn >> 3) & 7; - addr = load_reg(s, rn); - val = (insn >> 6) & 0x1f; - tcg_gen_addi_i32(addr, addr, val); - - if (insn & (1 << 11)) { - /* load */ - tmp = gen_ld8u(addr, IS_USER(s)); - store_reg(s, rd, tmp); - } else { - /* store */ - tmp = load_reg(s, rd); - gen_st8(tmp, addr, IS_USER(s)); - } - dead_tmp(addr); - break; - - case 8: - /* load/store halfword immediate offset */ - rd = insn & 7; - rn = (insn >> 3) & 7; - addr = load_reg(s, rn); - val = (insn >> 5) & 0x3e; - tcg_gen_addi_i32(addr, addr, val); - - if (insn & (1 << 11)) { - /* load */ - tmp = gen_ld16u(addr, IS_USER(s)); - store_reg(s, rd, tmp); - } else { - /* store */ - tmp = load_reg(s, rd); - gen_st16(tmp, addr, IS_USER(s)); - } - dead_tmp(addr); - break; - - case 9: - /* load/store from stack */ - rd = (insn >> 8) & 7; - addr = load_reg(s, 13); - val = (insn & 0xff) * 4; - tcg_gen_addi_i32(addr, addr, val); - - if (insn & (1 << 11)) { - /* load */ - tmp = gen_ld32(addr, IS_USER(s)); - store_reg(s, rd, tmp); - } else { - /* store */ - tmp = load_reg(s, rd); - gen_st32(tmp, addr, IS_USER(s)); - } - dead_tmp(addr); - break; - - case 10: - /* add to high reg */ - rd = (insn >> 8) & 7; - if (insn & (1 << 11)) { - /* SP */ - tmp = load_reg(s, 13); - } else { - /* PC. bit 1 is ignored. */ - tmp = new_tmp(); - tcg_gen_movi_i32(tmp, (s->pc + 2) & ~(uint32_t)2); - } - val = (insn & 0xff) * 4; - tcg_gen_addi_i32(tmp, tmp, val); - store_reg(s, rd, tmp); - break; - - case 11: - /* misc */ - op = (insn >> 8) & 0xf; - switch (op) { - case 0: - /* adjust stack pointer */ - tmp = load_reg(s, 13); - val = (insn & 0x7f) * 4; - if (insn & (1 << 7)) - val = -(int32_t)val; - tcg_gen_addi_i32(tmp, tmp, val); - store_reg(s, 13, tmp); - break; - - case 2: /* sign/zero extend. */ - ARCH(6); - rd = insn & 7; - rm = (insn >> 3) & 7; - tmp = load_reg(s, rm); - switch ((insn >> 6) & 3) { - case 0: gen_sxth(tmp); break; - case 1: gen_sxtb(tmp); break; - case 2: gen_uxth(tmp); break; - case 3: gen_uxtb(tmp); break; - } - store_reg(s, rd, tmp); - break; - case 4: case 5: case 0xc: case 0xd: - /* push/pop */ - addr = load_reg(s, 13); - if (insn & (1 << 8)) - offset = 4; - else - offset = 0; - for (i = 0; i < 8; i++) { - if (insn & (1 << i)) - offset += 4; - } - if ((insn & (1 << 11)) == 0) { - tcg_gen_addi_i32(addr, addr, -offset); - } - for (i = 0; i < 8; i++) { - if (insn & (1 << i)) { - if (insn & (1 << 11)) { - /* pop */ - tmp = gen_ld32(addr, IS_USER(s)); - store_reg(s, i, tmp); - } else { - /* push */ - tmp = load_reg(s, i); - gen_st32(tmp, addr, IS_USER(s)); - } - /* advance to the next address. */ - tcg_gen_addi_i32(addr, addr, 4); - } - } - TCGV_UNUSED(tmp); - if (insn & (1 << 8)) { - if (insn & (1 << 11)) { - /* pop pc */ - tmp = gen_ld32(addr, IS_USER(s)); - /* don't set the pc until the rest of the instruction - has completed */ - } else { - /* push lr */ - tmp = load_reg(s, 14); - gen_st32(tmp, addr, IS_USER(s)); - } - tcg_gen_addi_i32(addr, addr, 4); - } - if ((insn & (1 << 11)) == 0) { - tcg_gen_addi_i32(addr, addr, -offset); - } - /* write back the new stack pointer */ - store_reg(s, 13, addr); - /* set the new PC value */ - if ((insn & 0x0900) == 0x0900) - gen_bx(s, tmp); - break; - - case 1: case 3: case 9: case 11: /* czb */ - rm = insn & 7; - tmp = load_reg(s, rm); - s->condlabel = gen_new_label(); - s->condjmp = 1; - if (insn & (1 << 11)) - tcg_gen_brcondi_i32(TCG_COND_EQ, tmp, 0, s->condlabel); - else - tcg_gen_brcondi_i32(TCG_COND_NE, tmp, 0, s->condlabel); - dead_tmp(tmp); - offset = ((insn & 0xf8) >> 2) | (insn & 0x200) >> 3; - val = (uint32_t)s->pc + 2; - val += offset; - gen_jmp(s, val); - break; - - case 15: /* IT, nop-hint. */ - if ((insn & 0xf) == 0) { - gen_nop_hint(s, (insn >> 4) & 0xf); - break; - } - /* If Then. */ - s->condexec_cond = (insn >> 4) & 0xe; - s->condexec_mask = insn & 0x1f; - /* No actual code generated for this insn, just setup state. */ - break; - - case 0xe: /* bkpt */ - gen_set_condexec(s); - gen_set_pc_im(s->pc - 2); - gen_exception(EXCP_BKPT); - s->is_jmp = DISAS_JUMP; - break; - - case 0xa: /* rev */ - ARCH(6); - rn = (insn >> 3) & 0x7; - rd = insn & 0x7; - tmp = load_reg(s, rn); - switch ((insn >> 6) & 3) { - case 0: tcg_gen_bswap32_i32(tmp, tmp); break; - case 1: gen_rev16(tmp); break; - case 3: gen_revsh(tmp); break; - default: goto illegal_op; - } - store_reg(s, rd, tmp); - break; - - case 6: /* cps */ - ARCH(6); - if (IS_USER(s)) - break; - if (IS_M(env)) { - tmp = tcg_const_i32((insn & (1 << 4)) != 0); - /* PRIMASK */ - if (insn & 1) { - addr = tcg_const_i32(16); - gen_helper_v7m_msr(cpu_env, addr, tmp); - tcg_temp_free_i32(addr); - } - /* FAULTMASK */ - if (insn & 2) { - addr = tcg_const_i32(17); - gen_helper_v7m_msr(cpu_env, addr, tmp); - tcg_temp_free_i32(addr); - } - tcg_temp_free_i32(tmp); - gen_lookup_tb(s); - } else { - if (insn & (1 << 4)) - shift = CPSR_A | CPSR_I | CPSR_F; - else - shift = 0; - gen_set_psr_im(s, shift, 0, ((insn & 7) << 6) & shift); - } - break; - - default: - goto undef; - } - break; - - case 12: - /* load/store multiple */ - rn = (insn >> 8) & 0x7; - addr = load_reg(s, rn); - for (i = 0; i < 8; i++) { - if (insn & (1 << i)) { - if (insn & (1 << 11)) { - /* load */ - tmp = gen_ld32(addr, IS_USER(s)); - store_reg(s, i, tmp); - } else { - /* store */ - tmp = load_reg(s, i); - gen_st32(tmp, addr, IS_USER(s)); - } - /* advance to the next address */ - tcg_gen_addi_i32(addr, addr, 4); - } - } - /* Base register writeback. */ - if ((insn & (1 << rn)) == 0) { - store_reg(s, rn, addr); - } else { - dead_tmp(addr); - } - break; - - case 13: - /* conditional branch or swi */ - cond = (insn >> 8) & 0xf; - if (cond == 0xe) - goto undef; - - if (cond == 0xf) { - /* swi */ - gen_set_condexec(s); - gen_set_pc_im(s->pc); - s->is_jmp = DISAS_SWI; - break; - } - /* generate a conditional jump to next instruction */ - s->condlabel = gen_new_label(); - gen_test_cc(cond ^ 1, s->condlabel); - s->condjmp = 1; - - /* jump to the offset */ - val = (uint32_t)s->pc + 2; - offset = ((int32_t)insn << 24) >> 24; - val += offset << 1; - gen_jmp(s, val); - break; - - case 14: - if (insn & (1 << 11)) { - if (disas_thumb2_insn(env, s, insn)) - goto undef32; - break; - } - /* unconditional branch */ - val = (uint32_t)s->pc; - offset = ((int32_t)insn << 21) >> 21; - val += (offset << 1) + 2; - gen_jmp(s, val); - break; - - case 15: - if (disas_thumb2_insn(env, s, insn)) - goto undef32; - break; - } - return; -undef32: - gen_set_condexec(s); - gen_set_pc_im(s->pc - 4); - gen_exception(EXCP_UDEF); - s->is_jmp = DISAS_JUMP; - return; -illegal_op: -undef: - gen_set_condexec(s); - gen_set_pc_im(s->pc - 2); - gen_exception(EXCP_UDEF); - s->is_jmp = DISAS_JUMP; -} - -/* generate intermediate code in gen_opc_buf and gen_opparam_buf for - basic block 'tb'. If search_pc is TRUE, also generate PC - information for each intermediate instruction. */ -static inline void gen_intermediate_code_internal(CPUState *env, - TranslationBlock *tb, - int search_pc) -{ - DisasContext dc1, *dc = &dc1; - CPUBreakpoint *bp; - uint16_t *gen_opc_end; - int j, lj; - target_ulong pc_start; - uint32_t next_page_start; - int num_insns; - int max_insns; - - /* generate intermediate code */ - num_temps = 0; - - pc_start = tb->pc; - - dc->tb = tb; - - gen_opc_end = gen_opc_buf + OPC_MAX_SIZE; - - dc->is_jmp = DISAS_NEXT; - dc->pc = pc_start; - dc->singlestep_enabled = env->singlestep_enabled; - dc->condjmp = 0; - dc->thumb = env->thumb; - dc->condexec_mask = (env->condexec_bits & 0xf) << 1; - dc->condexec_cond = env->condexec_bits >> 4; -#if !defined(CONFIG_USER_ONLY) - if (IS_M(env)) { - dc->user = ((env->v7m.exception == 0) && (env->v7m.control & 1)); - } else { - dc->user = (env->uncached_cpsr & 0x1f) == ARM_CPU_MODE_USR; - } -#endif - cpu_F0s = tcg_temp_new_i32(); - cpu_F1s = tcg_temp_new_i32(); - cpu_F0d = tcg_temp_new_i64(); - cpu_F1d = tcg_temp_new_i64(); - cpu_V0 = cpu_F0d; - cpu_V1 = cpu_F1d; - /* FIXME: cpu_M0 can probably be the same as cpu_V0. */ - cpu_M0 = tcg_temp_new_i64(); - next_page_start = (pc_start & TARGET_PAGE_MASK) + TARGET_PAGE_SIZE; - lj = -1; - num_insns = 0; - max_insns = tb->cflags & CF_COUNT_MASK; - if (max_insns == 0) - max_insns = CF_COUNT_MASK; - - gen_icount_start(); - /* Reset the conditional execution bits immediately. This avoids - complications trying to do it at the end of the block. */ - if (env->condexec_bits) - { - TCGv tmp = new_tmp(); - tcg_gen_movi_i32(tmp, 0); - store_cpu_field(tmp, condexec_bits); - } - do { -#ifdef CONFIG_USER_ONLY - /* Intercept jump to the magic kernel page. */ - if (dc->pc >= 0xffff0000) { - /* We always get here via a jump, so know we are not in a - conditional execution block. */ - gen_exception(EXCP_KERNEL_TRAP); - dc->is_jmp = DISAS_UPDATE; - break; - } -#else - if (dc->pc >= 0xfffffff0 && IS_M(env)) { - /* We always get here via a jump, so know we are not in a - conditional execution block. */ - gen_exception(EXCP_EXCEPTION_EXIT); - dc->is_jmp = DISAS_UPDATE; - break; - } -#endif - - if (unlikely(!QTAILQ_EMPTY(&env->breakpoints))) { - QTAILQ_FOREACH(bp, &env->breakpoints, entry) { - if (bp->pc == dc->pc) { - gen_set_condexec(dc); - gen_set_pc_im(dc->pc); - gen_exception(EXCP_DEBUG); - dc->is_jmp = DISAS_JUMP; - /* Advance PC so that clearing the breakpoint will - invalidate this TB. */ - dc->pc += 2; - goto done_generating; - break; - } - } - } - if (search_pc) { - j = gen_opc_ptr - gen_opc_buf; - if (lj < j) { - lj++; - while (lj < j) - gen_opc_instr_start[lj++] = 0; - } - gen_opc_pc[lj] = dc->pc; - gen_opc_instr_start[lj] = 1; - gen_opc_icount[lj] = num_insns; - } - - if (num_insns + 1 == max_insns && (tb->cflags & CF_LAST_IO)) - gen_io_start(); - - if (env->thumb) { - disas_thumb_insn(env, dc); - if (dc->condexec_mask) { - dc->condexec_cond = (dc->condexec_cond & 0xe) - | ((dc->condexec_mask >> 4) & 1); - dc->condexec_mask = (dc->condexec_mask << 1) & 0x1f; - if (dc->condexec_mask == 0) { - dc->condexec_cond = 0; - } - } - } else { - disas_arm_insn(env, dc); - } - if (num_temps) { - fprintf(stderr, "Internal resource leak before %08x\n", dc->pc); - num_temps = 0; - } - - if (dc->condjmp && !dc->is_jmp) { - gen_set_label(dc->condlabel); - dc->condjmp = 0; - } - /* Translation stops when a conditional branch is encountered. - * Otherwise the subsequent code could get translated several times. - * Also stop translation when a page boundary is reached. This - * ensures prefetch aborts occur at the right place. */ - num_insns ++; - } while (!dc->is_jmp && gen_opc_ptr < gen_opc_end && - !env->singlestep_enabled && - !singlestep && - dc->pc < next_page_start && - num_insns < max_insns); - - if (tb->cflags & CF_LAST_IO) { - if (dc->condjmp) { - /* FIXME: This can theoretically happen with self-modifying - code. */ - cpu_abort(env, "IO on conditional branch instruction"); - } - gen_io_end(); - } - - /* At this stage dc->condjmp will only be set when the skipped - instruction was a conditional branch or trap, and the PC has - already been written. */ - if (unlikely(env->singlestep_enabled)) { - /* Make sure the pc is updated, and raise a debug exception. */ - if (dc->condjmp) { - gen_set_condexec(dc); - if (dc->is_jmp == DISAS_SWI) { - gen_exception(EXCP_SWI); - } else { - gen_exception(EXCP_DEBUG); - } - gen_set_label(dc->condlabel); - } - if (dc->condjmp || !dc->is_jmp) { - gen_set_pc_im(dc->pc); - dc->condjmp = 0; - } - gen_set_condexec(dc); - if (dc->is_jmp == DISAS_SWI && !dc->condjmp) { - gen_exception(EXCP_SWI); - } else { - /* FIXME: Single stepping a WFI insn will not halt - the CPU. */ - gen_exception(EXCP_DEBUG); - } - } else { - /* While branches must always occur at the end of an IT block, - there are a few other things that can cause us to terminate - the TB in the middel of an IT block: - - Exception generating instructions (bkpt, swi, undefined). - - Page boundaries. - - Hardware watchpoints. - Hardware breakpoints have already been handled and skip this code. - */ - gen_set_condexec(dc); - switch(dc->is_jmp) { - case DISAS_NEXT: - gen_goto_tb(dc, 1, dc->pc); - break; - default: - case DISAS_JUMP: - case DISAS_UPDATE: - /* indicate that the hash table must be used to find the next TB */ - tcg_gen_exit_tb(0); - break; - case DISAS_TB_JUMP: - /* nothing more to generate */ - break; - case DISAS_WFI: - gen_helper_wfi(); - break; - case DISAS_SWI: - gen_exception(EXCP_SWI); - break; - } - if (dc->condjmp) { - gen_set_label(dc->condlabel); - gen_set_condexec(dc); - gen_goto_tb(dc, 1, dc->pc); - dc->condjmp = 0; - } - } - -done_generating: - gen_icount_end(tb, num_insns); - *gen_opc_ptr = INDEX_op_end; - -#ifdef DEBUG_DISAS - if (qemu_loglevel_mask(CPU_LOG_TB_IN_ASM)) { - qemu_log("----------------\n"); - qemu_log("IN: %s\n", lookup_symbol(pc_start)); - log_target_disas(pc_start, dc->pc - pc_start, env->thumb); - qemu_log("\n"); - } -#endif - if (search_pc) { - j = gen_opc_ptr - gen_opc_buf; - lj++; - while (lj <= j) - gen_opc_instr_start[lj++] = 0; - } else { - tb->size = dc->pc - pc_start; - tb->icount = num_insns; - } -} - -void gen_intermediate_code(CPUState *env, TranslationBlock *tb) -{ - gen_intermediate_code_internal(env, tb, 0); -} - -void gen_intermediate_code_pc(CPUState *env, TranslationBlock *tb) -{ - gen_intermediate_code_internal(env, tb, 1); -} - -static const char *cpu_mode_names[16] = { - "usr", "fiq", "irq", "svc", "???", "???", "???", "abt", - "???", "???", "???", "und", "???", "???", "???", "sys" -}; - -void cpu_dump_state(CPUState *env, FILE *f, - int (*cpu_fprintf)(FILE *f, const char *fmt, ...), - int flags) -{ - int i; -#if 0 - union { - uint32_t i; - float s; - } s0, s1; - CPU_DoubleU d; - /* ??? This assumes float64 and double have the same layout. - Oh well, it's only debug dumps. */ - union { - float64 f64; - double d; - } d0; -#endif - uint32_t psr; - - for(i=0;i<16;i++) { - cpu_fprintf(f, "R%02d=%08x", i, env->regs[i]); - if ((i % 4) == 3) - cpu_fprintf(f, "\n"); - else - cpu_fprintf(f, " "); - } - psr = cpsr_read(env); - cpu_fprintf(f, "PSR=%08x %c%c%c%c %c %s%d\n", - psr, - psr & (1 << 31) ? 'N' : '-', - psr & (1 << 30) ? 'Z' : '-', - psr & (1 << 29) ? 'C' : '-', - psr & (1 << 28) ? 'V' : '-', - psr & CPSR_T ? 'T' : 'A', - cpu_mode_names[psr & 0xf], (psr & 0x10) ? 32 : 26); - -#if 0 - for (i = 0; i < 16; i++) { - d.d = env->vfp.regs[i]; - s0.i = d.l.lower; - s1.i = d.l.upper; - d0.f64 = d.d; - cpu_fprintf(f, "s%02d=%08x(%8g) s%02d=%08x(%8g) d%02d=%08x%08x(%8g)\n", - i * 2, (int)s0.i, s0.s, - i * 2 + 1, (int)s1.i, s1.s, - i, (int)(uint32_t)d.l.upper, (int)(uint32_t)d.l.lower, - d0.d); - } - cpu_fprintf(f, "FPSCR: %08x\n", (int)env->vfp.xregs[ARM_VFP_FPSCR]); -#endif -} - -void gen_pc_load(CPUState *env, TranslationBlock *tb, - unsigned long searched_pc, int pc_pos, void *puc) -{ - env->regs[15] = gen_opc_pc[pc_pos]; -} diff --git a/qemu/qemu-git/tcg/.svn/all-wcprops b/qemu/qemu-git/tcg/.svn/all-wcprops deleted file mode 100644 index 630ca68..0000000 --- a/qemu/qemu-git/tcg/.svn/all-wcprops +++ /dev/null @@ -1,53 +0,0 @@ -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg -END -tcg-op.h -K 25 -svn:wc:ra_dav:version-url -V 52 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/tcg-op.h -END -LICENSE -K 25 -svn:wc:ra_dav:version-url -V 51 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/LICENSE -END -tcg-opc.h -K 25 -svn:wc:ra_dav:version-url -V 53 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/tcg-opc.h -END -tcg.h -K 25 -svn:wc:ra_dav:version-url -V 49 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/tcg.h -END -tcg-runtime.h -K 25 -svn:wc:ra_dav:version-url -V 57 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/tcg-runtime.h -END -TODO -K 25 -svn:wc:ra_dav:version-url -V 48 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/TODO -END -README -K 25 -svn:wc:ra_dav:version-url -V 50 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/README -END -tcg.c -K 25 -svn:wc:ra_dav:version-url -V 49 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/tcg.c -END diff --git a/qemu/qemu-git/tcg/.svn/entries b/qemu/qemu-git/tcg/.svn/entries deleted file mode 100644 index a14c7b9..0000000 --- a/qemu/qemu-git/tcg/.svn/entries +++ /dev/null @@ -1,327 +0,0 @@ -10 - -dir -11 -http://svn.code.sf.net/p/x49gp/code/qemu/qemu-git/tcg -http://svn.code.sf.net/p/x49gp/code - - - -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - -481df3bd-3408-496c-b7de-451e46197bb5 - -tcg-op.h -file - - - - -2013-08-23T00:54:47.000000Z -751d2dc7d578e005034d93bc0801afc9 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -65136 - -arm -dir - -tcg-opc.h -file - - - - -2013-08-23T00:54:47.000000Z -4a07134a8350e09a6eb1085a8e1a8590 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -8525 - -LICENSE -file - - - - -2013-08-23T00:54:47.000000Z -d11ae3b9d7c6d64e64f06995ce28562d -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -146 - -ppc -dir - -tcg-runtime.h -file - - - - -2013-08-23T00:54:47.000000Z -0e7974b77cf2837825d42e5b779e02f9 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -473 - -hppa -dir - -i386 -dir - -ppc64 -dir - -README -file - - - - -2013-08-23T00:54:47.000000Z -dd8f60487ad8672620cad0409eca48bc -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -12734 - -tcg.c -file - - - - -2013-08-23T00:54:47.000000Z -b5d3f59022049ce9ae244bcc8b5afca4 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -63169 - -s390 -dir - -x86_64 -dir - -tcg.h -file - - - - -2013-08-23T00:54:47.000000Z -17474dfcc15b2bcef749275db5f8ec97 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -14312 - -TODO -file - - - - -2013-08-23T00:54:47.000000Z -bf07003b0e637aa264b95f358e1da643 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -403 - -mips -dir - -sparc -dir - diff --git a/qemu/qemu-git/tcg/.svn/text-base/LICENSE.svn-base b/qemu/qemu-git/tcg/.svn/text-base/LICENSE.svn-base deleted file mode 100644 index be817fa..0000000 --- a/qemu/qemu-git/tcg/.svn/text-base/LICENSE.svn-base +++ /dev/null @@ -1,3 +0,0 @@ -All the files in this directory and subdirectories are released under -a BSD like license (see header in each file). No other license is -accepted. diff --git a/qemu/qemu-git/tcg/.svn/text-base/README.svn-base b/qemu/qemu-git/tcg/.svn/text-base/README.svn-base deleted file mode 100644 index e672258..0000000 --- a/qemu/qemu-git/tcg/.svn/text-base/README.svn-base +++ /dev/null @@ -1,454 +0,0 @@ -Tiny Code Generator - Fabrice Bellard. - -1) Introduction - -TCG (Tiny Code Generator) began as a generic backend for a C -compiler. It was simplified to be used in QEMU. It also has its roots -in the QOP code generator written by Paul Brook. - -2) Definitions - -The TCG "target" is the architecture for which we generate the -code. It is of course not the same as the "target" of QEMU which is -the emulated architecture. As TCG started as a generic C backend used -for cross compiling, it is assumed that the TCG target is different -from the host, although it is never the case for QEMU. - -A TCG "function" corresponds to a QEMU Translated Block (TB). - -A TCG "temporary" is a variable only live in a basic -block. Temporaries are allocated explicitly in each function. - -A TCG "local temporary" is a variable only live in a function. Local -temporaries are allocated explicitly in each function. - -A TCG "global" is a variable which is live in all the functions -(equivalent of a C global variable). They are defined before the -functions defined. A TCG global can be a memory location (e.g. a QEMU -CPU register), a fixed host register (e.g. the QEMU CPU state pointer) -or a memory location which is stored in a register outside QEMU TBs -(not implemented yet). - -A TCG "basic block" corresponds to a list of instructions terminated -by a branch instruction. - -3) Intermediate representation - -3.1) Introduction - -TCG instructions operate on variables which are temporaries, local -temporaries or globals. TCG instructions and variables are strongly -typed. Two types are supported: 32 bit integers and 64 bit -integers. Pointers are defined as an alias to 32 bit or 64 bit -integers depending on the TCG target word size. - -Each instruction has a fixed number of output variable operands, input -variable operands and always constant operands. - -The notable exception is the call instruction which has a variable -number of outputs and inputs. - -In the textual form, output operands usually come first, followed by -input operands, followed by constant operands. The output type is -included in the instruction name. Constants are prefixed with a '$'. - -add_i32 t0, t1, t2 (t0 <- t1 + t2) - -3.2) Assumptions - -* Basic blocks - -- Basic blocks end after branches (e.g. brcond_i32 instruction), - goto_tb and exit_tb instructions. -- Basic blocks start after the end of a previous basic block, or at a - set_label instruction. - -After the end of a basic block, the content of temporaries is -destroyed, but local temporaries and globals are preserved. - -* Floating point types are not supported yet - -* Pointers: depending on the TCG target, pointer size is 32 bit or 64 - bit. The type TCG_TYPE_PTR is an alias to TCG_TYPE_I32 or - TCG_TYPE_I64. - -* Helpers: - -Using the tcg_gen_helper_x_y it is possible to call any function -taking i32, i64 or pointer types. Before calling an helper, all -globals are stored at their canonical location and it is assumed that -the function can modify them. In the future, function modifiers will -be allowed to tell that the helper does not read or write some globals. - -On some TCG targets (e.g. x86), several calling conventions are -supported. - -* Branches: - -Use the instruction 'br' to jump to a label. Use 'jmp' to jump to an -explicit address. Conditional branches can only jump to labels. - -3.3) Code Optimizations - -When generating instructions, you can count on at least the following -optimizations: - -- Single instructions are simplified, e.g. - - and_i32 t0, t0, $0xffffffff - - is suppressed. - -- A liveness analysis is done at the basic block level. The - information is used to suppress moves from a dead variable to - another one. It is also used to remove instructions which compute - dead results. The later is especially useful for condition code - optimization in QEMU. - - In the following example: - - add_i32 t0, t1, t2 - add_i32 t0, t0, $1 - mov_i32 t0, $1 - - only the last instruction is kept. - -3.4) Instruction Reference - -********* Function call - -* call ptr - -call function 'ptr' (pointer type) - - optional 32 bit or 64 bit return value - optional 32 bit or 64 bit parameters - -********* Jumps/Labels - -* jmp t0 - -Absolute jump to address t0 (pointer type). - -* set_label $label - -Define label 'label' at the current program point. - -* br $label - -Jump to label. - -* brcond_i32/i64 cond, t0, t1, label - -Conditional jump if t0 cond t1 is true. cond can be: - TCG_COND_EQ - TCG_COND_NE - TCG_COND_LT /* signed */ - TCG_COND_GE /* signed */ - TCG_COND_LE /* signed */ - TCG_COND_GT /* signed */ - TCG_COND_LTU /* unsigned */ - TCG_COND_GEU /* unsigned */ - TCG_COND_LEU /* unsigned */ - TCG_COND_GTU /* unsigned */ - -********* Arithmetic - -* add_i32/i64 t0, t1, t2 - -t0=t1+t2 - -* sub_i32/i64 t0, t1, t2 - -t0=t1-t2 - -* neg_i32/i64 t0, t1 - -t0=-t1 (two's complement) - -* mul_i32/i64 t0, t1, t2 - -t0=t1*t2 - -* div_i32/i64 t0, t1, t2 - -t0=t1/t2 (signed). Undefined behavior if division by zero or overflow. - -* divu_i32/i64 t0, t1, t2 - -t0=t1/t2 (unsigned). Undefined behavior if division by zero. - -* rem_i32/i64 t0, t1, t2 - -t0=t1%t2 (signed). Undefined behavior if division by zero or overflow. - -* remu_i32/i64 t0, t1, t2 - -t0=t1%t2 (unsigned). Undefined behavior if division by zero. - -********* Logical - -* and_i32/i64 t0, t1, t2 - -t0=t1&t2 - -* or_i32/i64 t0, t1, t2 - -t0=t1|t2 - -* xor_i32/i64 t0, t1, t2 - -t0=t1^t2 - -* not_i32/i64 t0, t1 - -t0=~t1 - -* andc_i32/i64 t0, t1, t2 - -t0=t1&~t2 - -* eqv_i32/i64 t0, t1, t2 - -t0=~(t1^t2) - -* nand_i32/i64 t0, t1, t2 - -t0=~(t1&t2) - -* nor_i32/i64 t0, t1, t2 - -t0=~(t1|t2) - -* orc_i32/i64 t0, t1, t2 - -t0=t1|~t2 - -********* Shifts/Rotates - -* shl_i32/i64 t0, t1, t2 - -t0=t1 << t2. Undefined behavior if t2 < 0 or t2 >= 32 (resp 64) - -* shr_i32/i64 t0, t1, t2 - -t0=t1 >> t2 (unsigned). Undefined behavior if t2 < 0 or t2 >= 32 (resp 64) - -* sar_i32/i64 t0, t1, t2 - -t0=t1 >> t2 (signed). Undefined behavior if t2 < 0 or t2 >= 32 (resp 64) - -* rotl_i32/i64 t0, t1, t2 - -Rotation of t2 bits to the left. Undefined behavior if t2 < 0 or t2 >= 32 (resp 64) - -* rotr_i32/i64 t0, t1, t2 - -Rotation of t2 bits to the right. Undefined behavior if t2 < 0 or t2 >= 32 (resp 64) - -********* Misc - -* mov_i32/i64 t0, t1 - -t0 = t1 - -Move t1 to t0 (both operands must have the same type). - -* ext8s_i32/i64 t0, t1 -ext8u_i32/i64 t0, t1 -ext16s_i32/i64 t0, t1 -ext16u_i32/i64 t0, t1 -ext32s_i64 t0, t1 -ext32u_i64 t0, t1 - -8, 16 or 32 bit sign/zero extension (both operands must have the same type) - -* bswap16_i32/i64 t0, t1 - -16 bit byte swap on a 32/64 bit value. The two/six high order bytes must be -set to zero. - -* bswap32_i32/i64 t0, t1 - -32 bit byte swap on a 32/64 bit value. With a 64 bit value, the four high -order bytes must be set to zero. - -* bswap64_i64 t0, t1 - -64 bit byte swap - -* discard_i32/i64 t0 - -Indicate that the value of t0 won't be used later. It is useful to -force dead code elimination. - -********* Type conversions - -* ext_i32_i64 t0, t1 -Convert t1 (32 bit) to t0 (64 bit) and does sign extension - -* extu_i32_i64 t0, t1 -Convert t1 (32 bit) to t0 (64 bit) and does zero extension - -* trunc_i64_i32 t0, t1 -Truncate t1 (64 bit) to t0 (32 bit) - -* concat_i32_i64 t0, t1, t2 -Construct t0 (64-bit) taking the low half from t1 (32 bit) and the high half -from t2 (32 bit). - -* concat32_i64 t0, t1, t2 -Construct t0 (64-bit) taking the low half from t1 (64 bit) and the high half -from t2 (64 bit). - -********* Load/Store - -* ld_i32/i64 t0, t1, offset -ld8s_i32/i64 t0, t1, offset -ld8u_i32/i64 t0, t1, offset -ld16s_i32/i64 t0, t1, offset -ld16u_i32/i64 t0, t1, offset -ld32s_i64 t0, t1, offset -ld32u_i64 t0, t1, offset - -t0 = read(t1 + offset) -Load 8, 16, 32 or 64 bits with or without sign extension from host memory. -offset must be a constant. - -* st_i32/i64 t0, t1, offset -st8_i32/i64 t0, t1, offset -st16_i32/i64 t0, t1, offset -st32_i64 t0, t1, offset - -write(t0, t1 + offset) -Write 8, 16, 32 or 64 bits to host memory. - -********* QEMU specific operations - -* tb_exit t0 - -Exit the current TB and return the value t0 (word type). - -* goto_tb index - -Exit the current TB and jump to the TB index 'index' (constant) if the -current TB was linked to this TB. Otherwise execute the next -instructions. - -* qemu_ld8u t0, t1, flags -qemu_ld8s t0, t1, flags -qemu_ld16u t0, t1, flags -qemu_ld16s t0, t1, flags -qemu_ld32u t0, t1, flags -qemu_ld32s t0, t1, flags -qemu_ld64 t0, t1, flags - -Load data at the QEMU CPU address t1 into t0. t1 has the QEMU CPU -address type. 'flags' contains the QEMU memory index (selects user or -kernel access) for example. - -* qemu_st8 t0, t1, flags -qemu_st16 t0, t1, flags -qemu_st32 t0, t1, flags -qemu_st64 t0, t1, flags - -Store the data t0 at the QEMU CPU Address t1. t1 has the QEMU CPU -address type. 'flags' contains the QEMU memory index (selects user or -kernel access) for example. - -Note 1: Some shortcuts are defined when the last operand is known to be -a constant (e.g. addi for add, movi for mov). - -Note 2: When using TCG, the opcodes must never be generated directly -as some of them may not be available as "real" opcodes. Always use the -function tcg_gen_xxx(args). - -4) Backend - -tcg-target.h contains the target specific definitions. tcg-target.c -contains the target specific code. - -4.1) Assumptions - -The target word size (TCG_TARGET_REG_BITS) is expected to be 32 bit or -64 bit. It is expected that the pointer has the same size as the word. - -On a 32 bit target, all 64 bit operations are converted to 32 bits. A -few specific operations must be implemented to allow it (see add2_i32, -sub2_i32, brcond2_i32). - -Floating point operations are not supported in this version. A -previous incarnation of the code generator had full support of them, -but it is better to concentrate on integer operations first. - -On a 64 bit target, no assumption is made in TCG about the storage of -the 32 bit values in 64 bit registers. - -4.2) Constraints - -GCC like constraints are used to define the constraints of every -instruction. Memory constraints are not supported in this -version. Aliases are specified in the input operands as for GCC. - -The same register may be used for both an input and an output, even when -they are not explicitly aliased. If an op expands to multiple target -instructions then care must be taken to avoid clobbering input values. -GCC style "early clobber" outputs are not currently supported. - -A target can define specific register or constant constraints. If an -operation uses a constant input constraint which does not allow all -constants, it must also accept registers in order to have a fallback. - -The movi_i32 and movi_i64 operations must accept any constants. - -The mov_i32 and mov_i64 operations must accept any registers of the -same type. - -The ld/st instructions must accept signed 32 bit constant offsets. It -can be implemented by reserving a specific register to compute the -address if the offset is too big. - -The ld/st instructions must accept any destination (ld) or source (st) -register. - -4.3) Function call assumptions - -- The only supported types for parameters and return value are: 32 and - 64 bit integers and pointer. -- The stack grows downwards. -- The first N parameters are passed in registers. -- The next parameters are passed on the stack by storing them as words. -- Some registers are clobbered during the call. -- The function can return 0 or 1 value in registers. On a 32 bit - target, functions must be able to return 2 values in registers for - 64 bit return type. - -5) Recommended coding rules for best performance - -- Use globals to represent the parts of the QEMU CPU state which are - often modified, e.g. the integer registers and the condition - codes. TCG will be able to use host registers to store them. - -- Avoid globals stored in fixed registers. They must be used only to - store the pointer to the CPU state and possibly to store a pointer - to a register window. - -- Use temporaries. Use local temporaries only when really needed, - e.g. when you need to use a value after a jump. Local temporaries - introduce a performance hit in the current TCG implementation: their - content is saved to memory at end of each basic block. - -- Free temporaries and local temporaries when they are no longer used - (tcg_temp_free). Since tcg_const_x() also creates a temporary, you - should free it after it is used. Freeing temporaries does not yield - a better generated code, but it reduces the memory usage of TCG and - the speed of the translation. - -- Don't hesitate to use helpers for complicated or seldom used target - intructions. There is little performance advantage in using TCG to - implement target instructions taking more than about twenty TCG - instructions. - -- Use the 'discard' instruction if you know that TCG won't be able to - prove that a given global is "dead" at a given program point. The - x86 target uses it to improve the condition codes optimisation. diff --git a/qemu/qemu-git/tcg/.svn/text-base/TODO.svn-base b/qemu/qemu-git/tcg/.svn/text-base/TODO.svn-base deleted file mode 100644 index f30cb75..0000000 --- a/qemu/qemu-git/tcg/.svn/text-base/TODO.svn-base +++ /dev/null @@ -1,14 +0,0 @@ -- Add new instructions such as: setcond, clz, ctz, popcnt. - -- See if it is worth exporting mul2, mulu2, div2, divu2. - -- Support of globals saved in fixed registers between TBs. - -Ideas: - -- Move the slow part of the qemu_ld/st ops after the end of the TB. - -- Change exception syntax to get closer to QOP system (exception - parameters given with a specific instruction). - -- Add float and vector support. diff --git a/qemu/qemu-git/tcg/.svn/text-base/tcg-op.h.svn-base b/qemu/qemu-git/tcg/.svn/text-base/tcg-op.h.svn-base deleted file mode 100644 index faf2e8b..0000000 --- a/qemu/qemu-git/tcg/.svn/text-base/tcg-op.h.svn-base +++ /dev/null @@ -1,2183 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2008 Fabrice Bellard - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ -#include "tcg.h" - -int gen_new_label(void); - -static inline void tcg_gen_op1_i32(int opc, TCGv_i32 arg1) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I32(arg1); -} - -static inline void tcg_gen_op1_i64(int opc, TCGv_i64 arg1) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I64(arg1); -} - -static inline void tcg_gen_op1i(int opc, TCGArg arg1) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = arg1; -} - -static inline void tcg_gen_op2_i32(int opc, TCGv_i32 arg1, TCGv_i32 arg2) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I32(arg1); - *gen_opparam_ptr++ = GET_TCGV_I32(arg2); -} - -static inline void tcg_gen_op2_i64(int opc, TCGv_i64 arg1, TCGv_i64 arg2) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I64(arg1); - *gen_opparam_ptr++ = GET_TCGV_I64(arg2); -} - -static inline void tcg_gen_op2i_i32(int opc, TCGv_i32 arg1, TCGArg arg2) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I32(arg1); - *gen_opparam_ptr++ = arg2; -} - -static inline void tcg_gen_op2i_i64(int opc, TCGv_i64 arg1, TCGArg arg2) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I64(arg1); - *gen_opparam_ptr++ = arg2; -} - -static inline void tcg_gen_op2ii(int opc, TCGArg arg1, TCGArg arg2) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = arg1; - *gen_opparam_ptr++ = arg2; -} - -static inline void tcg_gen_op3_i32(int opc, TCGv_i32 arg1, TCGv_i32 arg2, - TCGv_i32 arg3) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I32(arg1); - *gen_opparam_ptr++ = GET_TCGV_I32(arg2); - *gen_opparam_ptr++ = GET_TCGV_I32(arg3); -} - -static inline void tcg_gen_op3_i64(int opc, TCGv_i64 arg1, TCGv_i64 arg2, - TCGv_i64 arg3) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I64(arg1); - *gen_opparam_ptr++ = GET_TCGV_I64(arg2); - *gen_opparam_ptr++ = GET_TCGV_I64(arg3); -} - -static inline void tcg_gen_op3i_i32(int opc, TCGv_i32 arg1, TCGv_i32 arg2, - TCGArg arg3) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I32(arg1); - *gen_opparam_ptr++ = GET_TCGV_I32(arg2); - *gen_opparam_ptr++ = arg3; -} - -static inline void tcg_gen_op3i_i64(int opc, TCGv_i64 arg1, TCGv_i64 arg2, - TCGArg arg3) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I64(arg1); - *gen_opparam_ptr++ = GET_TCGV_I64(arg2); - *gen_opparam_ptr++ = arg3; -} - -static inline void tcg_gen_ldst_op_i32(int opc, TCGv_i32 val, TCGv_ptr base, - TCGArg offset) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I32(val); - *gen_opparam_ptr++ = GET_TCGV_PTR(base); - *gen_opparam_ptr++ = offset; -} - -static inline void tcg_gen_ldst_op_i64(int opc, TCGv_i64 val, TCGv_ptr base, - TCGArg offset) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I64(val); - *gen_opparam_ptr++ = GET_TCGV_PTR(base); - *gen_opparam_ptr++ = offset; -} - -static inline void tcg_gen_qemu_ldst_op_i64_i32(int opc, TCGv_i64 val, TCGv_i32 addr, - TCGArg mem_index) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I64(val); - *gen_opparam_ptr++ = GET_TCGV_I32(addr); - *gen_opparam_ptr++ = mem_index; -} - -static inline void tcg_gen_qemu_ldst_op_i64_i64(int opc, TCGv_i64 val, TCGv_i64 addr, - TCGArg mem_index) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I64(val); - *gen_opparam_ptr++ = GET_TCGV_I64(addr); - *gen_opparam_ptr++ = mem_index; -} - -static inline void tcg_gen_op4_i32(int opc, TCGv_i32 arg1, TCGv_i32 arg2, - TCGv_i32 arg3, TCGv_i32 arg4) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I32(arg1); - *gen_opparam_ptr++ = GET_TCGV_I32(arg2); - *gen_opparam_ptr++ = GET_TCGV_I32(arg3); - *gen_opparam_ptr++ = GET_TCGV_I32(arg4); -} - -static inline void tcg_gen_op4_i64(int opc, TCGv_i64 arg1, TCGv_i64 arg2, - TCGv_i64 arg3, TCGv_i64 arg4) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I64(arg1); - *gen_opparam_ptr++ = GET_TCGV_I64(arg2); - *gen_opparam_ptr++ = GET_TCGV_I64(arg3); - *gen_opparam_ptr++ = GET_TCGV_I64(arg4); -} - -static inline void tcg_gen_op4i_i32(int opc, TCGv_i32 arg1, TCGv_i32 arg2, - TCGv_i32 arg3, TCGArg arg4) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I32(arg1); - *gen_opparam_ptr++ = GET_TCGV_I32(arg2); - *gen_opparam_ptr++ = GET_TCGV_I32(arg3); - *gen_opparam_ptr++ = arg4; -} - -static inline void tcg_gen_op4i_i64(int opc, TCGv_i64 arg1, TCGv_i64 arg2, - TCGv_i64 arg3, TCGArg arg4) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I64(arg1); - *gen_opparam_ptr++ = GET_TCGV_I64(arg2); - *gen_opparam_ptr++ = GET_TCGV_I64(arg3); - *gen_opparam_ptr++ = arg4; -} - -static inline void tcg_gen_op4ii_i32(int opc, TCGv_i32 arg1, TCGv_i32 arg2, - TCGArg arg3, TCGArg arg4) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I32(arg1); - *gen_opparam_ptr++ = GET_TCGV_I32(arg2); - *gen_opparam_ptr++ = arg3; - *gen_opparam_ptr++ = arg4; -} - -static inline void tcg_gen_op4ii_i64(int opc, TCGv_i64 arg1, TCGv_i64 arg2, - TCGArg arg3, TCGArg arg4) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I64(arg1); - *gen_opparam_ptr++ = GET_TCGV_I64(arg2); - *gen_opparam_ptr++ = arg3; - *gen_opparam_ptr++ = arg4; -} - -static inline void tcg_gen_op5_i32(int opc, TCGv_i32 arg1, TCGv_i32 arg2, - TCGv_i32 arg3, TCGv_i32 arg4, TCGv_i32 arg5) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I32(arg1); - *gen_opparam_ptr++ = GET_TCGV_I32(arg2); - *gen_opparam_ptr++ = GET_TCGV_I32(arg3); - *gen_opparam_ptr++ = GET_TCGV_I32(arg4); - *gen_opparam_ptr++ = GET_TCGV_I32(arg5); -} - -static inline void tcg_gen_op5_i64(int opc, TCGv_i64 arg1, TCGv_i64 arg2, - TCGv_i64 arg3, TCGv_i64 arg4, TCGv_i64 arg5) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I64(arg1); - *gen_opparam_ptr++ = GET_TCGV_I64(arg2); - *gen_opparam_ptr++ = GET_TCGV_I64(arg3); - *gen_opparam_ptr++ = GET_TCGV_I64(arg4); - *gen_opparam_ptr++ = GET_TCGV_I64(arg5); -} - -static inline void tcg_gen_op5i_i32(int opc, TCGv_i32 arg1, TCGv_i32 arg2, - TCGv_i32 arg3, TCGv_i32 arg4, TCGArg arg5) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I32(arg1); - *gen_opparam_ptr++ = GET_TCGV_I32(arg2); - *gen_opparam_ptr++ = GET_TCGV_I32(arg3); - *gen_opparam_ptr++ = GET_TCGV_I32(arg4); - *gen_opparam_ptr++ = arg5; -} - -static inline void tcg_gen_op5i_i64(int opc, TCGv_i64 arg1, TCGv_i64 arg2, - TCGv_i64 arg3, TCGv_i64 arg4, TCGArg arg5) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I64(arg1); - *gen_opparam_ptr++ = GET_TCGV_I64(arg2); - *gen_opparam_ptr++ = GET_TCGV_I64(arg3); - *gen_opparam_ptr++ = GET_TCGV_I64(arg4); - *gen_opparam_ptr++ = arg5; -} - -static inline void tcg_gen_op6_i32(int opc, TCGv_i32 arg1, TCGv_i32 arg2, - TCGv_i32 arg3, TCGv_i32 arg4, TCGv_i32 arg5, - TCGv_i32 arg6) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I32(arg1); - *gen_opparam_ptr++ = GET_TCGV_I32(arg2); - *gen_opparam_ptr++ = GET_TCGV_I32(arg3); - *gen_opparam_ptr++ = GET_TCGV_I32(arg4); - *gen_opparam_ptr++ = GET_TCGV_I32(arg5); - *gen_opparam_ptr++ = GET_TCGV_I32(arg6); -} - -static inline void tcg_gen_op6_i64(int opc, TCGv_i64 arg1, TCGv_i64 arg2, - TCGv_i64 arg3, TCGv_i64 arg4, TCGv_i64 arg5, - TCGv_i64 arg6) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I64(arg1); - *gen_opparam_ptr++ = GET_TCGV_I64(arg2); - *gen_opparam_ptr++ = GET_TCGV_I64(arg3); - *gen_opparam_ptr++ = GET_TCGV_I64(arg4); - *gen_opparam_ptr++ = GET_TCGV_I64(arg5); - *gen_opparam_ptr++ = GET_TCGV_I64(arg6); -} - -static inline void tcg_gen_op6ii_i32(int opc, TCGv_i32 arg1, TCGv_i32 arg2, - TCGv_i32 arg3, TCGv_i32 arg4, TCGArg arg5, - TCGArg arg6) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I32(arg1); - *gen_opparam_ptr++ = GET_TCGV_I32(arg2); - *gen_opparam_ptr++ = GET_TCGV_I32(arg3); - *gen_opparam_ptr++ = GET_TCGV_I32(arg4); - *gen_opparam_ptr++ = arg5; - *gen_opparam_ptr++ = arg6; -} - -static inline void tcg_gen_op6ii_i64(int opc, TCGv_i64 arg1, TCGv_i64 arg2, - TCGv_i64 arg3, TCGv_i64 arg4, TCGArg arg5, - TCGArg arg6) -{ - *gen_opc_ptr++ = opc; - *gen_opparam_ptr++ = GET_TCGV_I64(arg1); - *gen_opparam_ptr++ = GET_TCGV_I64(arg2); - *gen_opparam_ptr++ = GET_TCGV_I64(arg3); - *gen_opparam_ptr++ = GET_TCGV_I64(arg4); - *gen_opparam_ptr++ = arg5; - *gen_opparam_ptr++ = arg6; -} - -static inline void gen_set_label(int n) -{ - tcg_gen_op1i(INDEX_op_set_label, n); -} - -static inline void tcg_gen_br(int label) -{ - tcg_gen_op1i(INDEX_op_br, label); -} - -static inline void tcg_gen_mov_i32(TCGv_i32 ret, TCGv_i32 arg) -{ - if (!TCGV_EQUAL_I32(ret, arg)) - tcg_gen_op2_i32(INDEX_op_mov_i32, ret, arg); -} - -static inline void tcg_gen_movi_i32(TCGv_i32 ret, int32_t arg) -{ - tcg_gen_op2i_i32(INDEX_op_movi_i32, ret, arg); -} - -/* helper calls */ -static inline void tcg_gen_helperN(void *func, int flags, int sizemask, - TCGArg ret, int nargs, TCGArg *args) -{ - TCGv_ptr fn; - fn = tcg_const_ptr((tcg_target_long)func); - tcg_gen_callN(&tcg_ctx, fn, flags, sizemask, ret, - nargs, args); - tcg_temp_free_ptr(fn); -} - -/* FIXME: Should this be pure? */ -static inline void tcg_gen_helper64(void *func, TCGv_i64 ret, - TCGv_i64 a, TCGv_i64 b) -{ - TCGv_ptr fn; - TCGArg args[2]; - fn = tcg_const_ptr((tcg_target_long)func); - args[0] = GET_TCGV_I64(a); - args[1] = GET_TCGV_I64(b); - tcg_gen_callN(&tcg_ctx, fn, 0, 7, GET_TCGV_I64(ret), 2, args); - tcg_temp_free_ptr(fn); -} - -/* 32 bit ops */ - -static inline void tcg_gen_ld8u_i32(TCGv_i32 ret, TCGv_ptr arg2, tcg_target_long offset) -{ - tcg_gen_ldst_op_i32(INDEX_op_ld8u_i32, ret, arg2, offset); -} - -static inline void tcg_gen_ld8s_i32(TCGv_i32 ret, TCGv_ptr arg2, tcg_target_long offset) -{ - tcg_gen_ldst_op_i32(INDEX_op_ld8s_i32, ret, arg2, offset); -} - -static inline void tcg_gen_ld16u_i32(TCGv_i32 ret, TCGv_ptr arg2, tcg_target_long offset) -{ - tcg_gen_ldst_op_i32(INDEX_op_ld16u_i32, ret, arg2, offset); -} - -static inline void tcg_gen_ld16s_i32(TCGv_i32 ret, TCGv_ptr arg2, tcg_target_long offset) -{ - tcg_gen_ldst_op_i32(INDEX_op_ld16s_i32, ret, arg2, offset); -} - -static inline void tcg_gen_ld_i32(TCGv_i32 ret, TCGv_ptr arg2, tcg_target_long offset) -{ - tcg_gen_ldst_op_i32(INDEX_op_ld_i32, ret, arg2, offset); -} - -static inline void tcg_gen_st8_i32(TCGv_i32 arg1, TCGv_ptr arg2, tcg_target_long offset) -{ - tcg_gen_ldst_op_i32(INDEX_op_st8_i32, arg1, arg2, offset); -} - -static inline void tcg_gen_st16_i32(TCGv_i32 arg1, TCGv_ptr arg2, tcg_target_long offset) -{ - tcg_gen_ldst_op_i32(INDEX_op_st16_i32, arg1, arg2, offset); -} - -static inline void tcg_gen_st_i32(TCGv_i32 arg1, TCGv_ptr arg2, tcg_target_long offset) -{ - tcg_gen_ldst_op_i32(INDEX_op_st_i32, arg1, arg2, offset); -} - -static inline void tcg_gen_add_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - tcg_gen_op3_i32(INDEX_op_add_i32, ret, arg1, arg2); -} - -static inline void tcg_gen_addi_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2) -{ - /* some cases can be optimized here */ - if (arg2 == 0) { - tcg_gen_mov_i32(ret, arg1); - } else { - TCGv_i32 t0 = tcg_const_i32(arg2); - tcg_gen_add_i32(ret, arg1, t0); - tcg_temp_free_i32(t0); - } -} - -static inline void tcg_gen_sub_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - tcg_gen_op3_i32(INDEX_op_sub_i32, ret, arg1, arg2); -} - -static inline void tcg_gen_subfi_i32(TCGv_i32 ret, int32_t arg1, TCGv_i32 arg2) -{ - TCGv_i32 t0 = tcg_const_i32(arg1); - tcg_gen_sub_i32(ret, t0, arg2); - tcg_temp_free_i32(t0); -} - -static inline void tcg_gen_subi_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2) -{ - /* some cases can be optimized here */ - if (arg2 == 0) { - tcg_gen_mov_i32(ret, arg1); - } else { - TCGv_i32 t0 = tcg_const_i32(arg2); - tcg_gen_sub_i32(ret, arg1, t0); - tcg_temp_free_i32(t0); - } -} - -static inline void tcg_gen_and_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - if (TCGV_EQUAL_I32(arg1, arg2)) { - tcg_gen_mov_i32(ret, arg1); - } else { - tcg_gen_op3_i32(INDEX_op_and_i32, ret, arg1, arg2); - } -} - -static inline void tcg_gen_andi_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2) -{ - /* some cases can be optimized here */ - if (arg2 == 0) { - tcg_gen_movi_i32(ret, 0); - } else if (arg2 == 0xffffffff) { - tcg_gen_mov_i32(ret, arg1); - } else { - TCGv_i32 t0 = tcg_const_i32(arg2); - tcg_gen_and_i32(ret, arg1, t0); - tcg_temp_free_i32(t0); - } -} - -static inline void tcg_gen_or_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - if (TCGV_EQUAL_I32(arg1, arg2)) { - tcg_gen_mov_i32(ret, arg1); - } else { - tcg_gen_op3_i32(INDEX_op_or_i32, ret, arg1, arg2); - } -} - -static inline void tcg_gen_ori_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2) -{ - /* some cases can be optimized here */ - if (arg2 == 0xffffffff) { - tcg_gen_movi_i32(ret, 0xffffffff); - } else if (arg2 == 0) { - tcg_gen_mov_i32(ret, arg1); - } else { - TCGv_i32 t0 = tcg_const_i32(arg2); - tcg_gen_or_i32(ret, arg1, t0); - tcg_temp_free_i32(t0); - } -} - -static inline void tcg_gen_xor_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - if (TCGV_EQUAL_I32(arg1, arg2)) { - tcg_gen_movi_i32(ret, 0); - } else { - tcg_gen_op3_i32(INDEX_op_xor_i32, ret, arg1, arg2); - } -} - -static inline void tcg_gen_xori_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2) -{ - /* some cases can be optimized here */ - if (arg2 == 0) { - tcg_gen_mov_i32(ret, arg1); - } else { - TCGv_i32 t0 = tcg_const_i32(arg2); - tcg_gen_xor_i32(ret, arg1, t0); - tcg_temp_free_i32(t0); - } -} - -static inline void tcg_gen_shl_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - tcg_gen_op3_i32(INDEX_op_shl_i32, ret, arg1, arg2); -} - -static inline void tcg_gen_shli_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2) -{ - if (arg2 == 0) { - tcg_gen_mov_i32(ret, arg1); - } else { - TCGv_i32 t0 = tcg_const_i32(arg2); - tcg_gen_shl_i32(ret, arg1, t0); - tcg_temp_free_i32(t0); - } -} - -static inline void tcg_gen_shr_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - tcg_gen_op3_i32(INDEX_op_shr_i32, ret, arg1, arg2); -} - -static inline void tcg_gen_shri_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2) -{ - if (arg2 == 0) { - tcg_gen_mov_i32(ret, arg1); - } else { - TCGv_i32 t0 = tcg_const_i32(arg2); - tcg_gen_shr_i32(ret, arg1, t0); - tcg_temp_free_i32(t0); - } -} - -static inline void tcg_gen_sar_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - tcg_gen_op3_i32(INDEX_op_sar_i32, ret, arg1, arg2); -} - -static inline void tcg_gen_sari_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2) -{ - if (arg2 == 0) { - tcg_gen_mov_i32(ret, arg1); - } else { - TCGv_i32 t0 = tcg_const_i32(arg2); - tcg_gen_sar_i32(ret, arg1, t0); - tcg_temp_free_i32(t0); - } -} - -static inline void tcg_gen_brcond_i32(int cond, TCGv_i32 arg1, TCGv_i32 arg2, - int label_index) -{ - tcg_gen_op4ii_i32(INDEX_op_brcond_i32, arg1, arg2, cond, label_index); -} - -static inline void tcg_gen_brcondi_i32(int cond, TCGv_i32 arg1, int32_t arg2, - int label_index) -{ - TCGv_i32 t0 = tcg_const_i32(arg2); - tcg_gen_brcond_i32(cond, arg1, t0, label_index); - tcg_temp_free_i32(t0); -} - -static inline void tcg_gen_mul_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - tcg_gen_op3_i32(INDEX_op_mul_i32, ret, arg1, arg2); -} - -static inline void tcg_gen_muli_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2) -{ - TCGv_i32 t0 = tcg_const_i32(arg2); - tcg_gen_mul_i32(ret, arg1, t0); - tcg_temp_free_i32(t0); -} - -#ifdef TCG_TARGET_HAS_div_i32 -static inline void tcg_gen_div_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - tcg_gen_op3_i32(INDEX_op_div_i32, ret, arg1, arg2); -} - -static inline void tcg_gen_rem_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - tcg_gen_op3_i32(INDEX_op_rem_i32, ret, arg1, arg2); -} - -static inline void tcg_gen_divu_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - tcg_gen_op3_i32(INDEX_op_divu_i32, ret, arg1, arg2); -} - -static inline void tcg_gen_remu_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - tcg_gen_op3_i32(INDEX_op_remu_i32, ret, arg1, arg2); -} -#else -static inline void tcg_gen_div_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - TCGv_i32 t0; - t0 = tcg_temp_new_i32(); - tcg_gen_sari_i32(t0, arg1, 31); - tcg_gen_op5_i32(INDEX_op_div2_i32, ret, t0, arg1, t0, arg2); - tcg_temp_free_i32(t0); -} - -static inline void tcg_gen_rem_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - TCGv_i32 t0; - t0 = tcg_temp_new_i32(); - tcg_gen_sari_i32(t0, arg1, 31); - tcg_gen_op5_i32(INDEX_op_div2_i32, t0, ret, arg1, t0, arg2); - tcg_temp_free_i32(t0); -} - -static inline void tcg_gen_divu_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - TCGv_i32 t0; - t0 = tcg_temp_new_i32(); - tcg_gen_movi_i32(t0, 0); - tcg_gen_op5_i32(INDEX_op_divu2_i32, ret, t0, arg1, t0, arg2); - tcg_temp_free_i32(t0); -} - -static inline void tcg_gen_remu_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - TCGv_i32 t0; - t0 = tcg_temp_new_i32(); - tcg_gen_movi_i32(t0, 0); - tcg_gen_op5_i32(INDEX_op_divu2_i32, t0, ret, arg1, t0, arg2); - tcg_temp_free_i32(t0); -} -#endif - -#if TCG_TARGET_REG_BITS == 32 - -static inline void tcg_gen_mov_i64(TCGv_i64 ret, TCGv_i64 arg) -{ - if (!TCGV_EQUAL_I64(ret, arg)) { - tcg_gen_mov_i32(TCGV_LOW(ret), TCGV_LOW(arg)); - tcg_gen_mov_i32(TCGV_HIGH(ret), TCGV_HIGH(arg)); - } -} - -static inline void tcg_gen_movi_i64(TCGv_i64 ret, int64_t arg) -{ - tcg_gen_movi_i32(TCGV_LOW(ret), arg); - tcg_gen_movi_i32(TCGV_HIGH(ret), arg >> 32); -} - -static inline void tcg_gen_ld8u_i64(TCGv_i64 ret, TCGv_ptr arg2, - tcg_target_long offset) -{ - tcg_gen_ld8u_i32(TCGV_LOW(ret), arg2, offset); - tcg_gen_movi_i32(TCGV_HIGH(ret), 0); -} - -static inline void tcg_gen_ld8s_i64(TCGv_i64 ret, TCGv_ptr arg2, - tcg_target_long offset) -{ - tcg_gen_ld8s_i32(TCGV_LOW(ret), arg2, offset); - tcg_gen_sari_i32(TCGV_HIGH(ret), TCGV_HIGH(ret), 31); -} - -static inline void tcg_gen_ld16u_i64(TCGv_i64 ret, TCGv_ptr arg2, - tcg_target_long offset) -{ - tcg_gen_ld16u_i32(TCGV_LOW(ret), arg2, offset); - tcg_gen_movi_i32(TCGV_HIGH(ret), 0); -} - -static inline void tcg_gen_ld16s_i64(TCGv_i64 ret, TCGv_ptr arg2, - tcg_target_long offset) -{ - tcg_gen_ld16s_i32(TCGV_LOW(ret), arg2, offset); - tcg_gen_sari_i32(TCGV_HIGH(ret), TCGV_LOW(ret), 31); -} - -static inline void tcg_gen_ld32u_i64(TCGv_i64 ret, TCGv_ptr arg2, - tcg_target_long offset) -{ - tcg_gen_ld_i32(TCGV_LOW(ret), arg2, offset); - tcg_gen_movi_i32(TCGV_HIGH(ret), 0); -} - -static inline void tcg_gen_ld32s_i64(TCGv_i64 ret, TCGv_ptr arg2, - tcg_target_long offset) -{ - tcg_gen_ld_i32(TCGV_LOW(ret), arg2, offset); - tcg_gen_sari_i32(TCGV_HIGH(ret), TCGV_LOW(ret), 31); -} - -static inline void tcg_gen_ld_i64(TCGv_i64 ret, TCGv_ptr arg2, - tcg_target_long offset) -{ - /* since arg2 and ret have different types, they cannot be the - same temporary */ -#ifdef TCG_TARGET_WORDS_BIGENDIAN - tcg_gen_ld_i32(TCGV_HIGH(ret), arg2, offset); - tcg_gen_ld_i32(TCGV_LOW(ret), arg2, offset + 4); -#else - tcg_gen_ld_i32(TCGV_LOW(ret), arg2, offset); - tcg_gen_ld_i32(TCGV_HIGH(ret), arg2, offset + 4); -#endif -} - -static inline void tcg_gen_st8_i64(TCGv_i64 arg1, TCGv_ptr arg2, - tcg_target_long offset) -{ - tcg_gen_st8_i32(TCGV_LOW(arg1), arg2, offset); -} - -static inline void tcg_gen_st16_i64(TCGv_i64 arg1, TCGv_ptr arg2, - tcg_target_long offset) -{ - tcg_gen_st16_i32(TCGV_LOW(arg1), arg2, offset); -} - -static inline void tcg_gen_st32_i64(TCGv_i64 arg1, TCGv_ptr arg2, - tcg_target_long offset) -{ - tcg_gen_st_i32(TCGV_LOW(arg1), arg2, offset); -} - -static inline void tcg_gen_st_i64(TCGv_i64 arg1, TCGv_ptr arg2, - tcg_target_long offset) -{ -#ifdef TCG_TARGET_WORDS_BIGENDIAN - tcg_gen_st_i32(TCGV_HIGH(arg1), arg2, offset); - tcg_gen_st_i32(TCGV_LOW(arg1), arg2, offset + 4); -#else - tcg_gen_st_i32(TCGV_LOW(arg1), arg2, offset); - tcg_gen_st_i32(TCGV_HIGH(arg1), arg2, offset + 4); -#endif -} - -static inline void tcg_gen_add_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_op6_i32(INDEX_op_add2_i32, TCGV_LOW(ret), TCGV_HIGH(ret), - TCGV_LOW(arg1), TCGV_HIGH(arg1), TCGV_LOW(arg2), - TCGV_HIGH(arg2)); -} - -static inline void tcg_gen_sub_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_op6_i32(INDEX_op_sub2_i32, TCGV_LOW(ret), TCGV_HIGH(ret), - TCGV_LOW(arg1), TCGV_HIGH(arg1), TCGV_LOW(arg2), - TCGV_HIGH(arg2)); -} - -static inline void tcg_gen_and_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_and_i32(TCGV_LOW(ret), TCGV_LOW(arg1), TCGV_LOW(arg2)); - tcg_gen_and_i32(TCGV_HIGH(ret), TCGV_HIGH(arg1), TCGV_HIGH(arg2)); -} - -static inline void tcg_gen_andi_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2) -{ - tcg_gen_andi_i32(TCGV_LOW(ret), TCGV_LOW(arg1), arg2); - tcg_gen_andi_i32(TCGV_HIGH(ret), TCGV_HIGH(arg1), arg2 >> 32); -} - -static inline void tcg_gen_or_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_or_i32(TCGV_LOW(ret), TCGV_LOW(arg1), TCGV_LOW(arg2)); - tcg_gen_or_i32(TCGV_HIGH(ret), TCGV_HIGH(arg1), TCGV_HIGH(arg2)); -} - -static inline void tcg_gen_ori_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2) -{ - tcg_gen_ori_i32(TCGV_LOW(ret), TCGV_LOW(arg1), arg2); - tcg_gen_ori_i32(TCGV_HIGH(ret), TCGV_HIGH(arg1), arg2 >> 32); -} - -static inline void tcg_gen_xor_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_xor_i32(TCGV_LOW(ret), TCGV_LOW(arg1), TCGV_LOW(arg2)); - tcg_gen_xor_i32(TCGV_HIGH(ret), TCGV_HIGH(arg1), TCGV_HIGH(arg2)); -} - -static inline void tcg_gen_xori_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2) -{ - tcg_gen_xori_i32(TCGV_LOW(ret), TCGV_LOW(arg1), arg2); - tcg_gen_xori_i32(TCGV_HIGH(ret), TCGV_HIGH(arg1), arg2 >> 32); -} - -/* XXX: use generic code when basic block handling is OK or CPU - specific code (x86) */ -static inline void tcg_gen_shl_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_helper64(tcg_helper_shl_i64, ret, arg1, arg2); -} - -static inline void tcg_gen_shli_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2) -{ - tcg_gen_shifti_i64(ret, arg1, arg2, 0, 0); -} - -static inline void tcg_gen_shr_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_helper64(tcg_helper_shr_i64, ret, arg1, arg2); -} - -static inline void tcg_gen_shri_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2) -{ - tcg_gen_shifti_i64(ret, arg1, arg2, 1, 0); -} - -static inline void tcg_gen_sar_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_helper64(tcg_helper_sar_i64, ret, arg1, arg2); -} - -static inline void tcg_gen_sari_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2) -{ - tcg_gen_shifti_i64(ret, arg1, arg2, 1, 1); -} - -static inline void tcg_gen_brcond_i64(int cond, TCGv_i64 arg1, TCGv_i64 arg2, - int label_index) -{ - tcg_gen_op6ii_i32(INDEX_op_brcond2_i32, - TCGV_LOW(arg1), TCGV_HIGH(arg1), TCGV_LOW(arg2), - TCGV_HIGH(arg2), cond, label_index); -} - -static inline void tcg_gen_mul_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - TCGv_i64 t0; - TCGv_i32 t1; - - t0 = tcg_temp_new_i64(); - t1 = tcg_temp_new_i32(); - - tcg_gen_op4_i32(INDEX_op_mulu2_i32, TCGV_LOW(t0), TCGV_HIGH(t0), - TCGV_LOW(arg1), TCGV_LOW(arg2)); - - tcg_gen_mul_i32(t1, TCGV_LOW(arg1), TCGV_HIGH(arg2)); - tcg_gen_add_i32(TCGV_HIGH(t0), TCGV_HIGH(t0), t1); - tcg_gen_mul_i32(t1, TCGV_HIGH(arg1), TCGV_LOW(arg2)); - tcg_gen_add_i32(TCGV_HIGH(t0), TCGV_HIGH(t0), t1); - - tcg_gen_mov_i64(ret, t0); - tcg_temp_free_i64(t0); - tcg_temp_free_i32(t1); -} - -static inline void tcg_gen_div_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_helper64(tcg_helper_div_i64, ret, arg1, arg2); -} - -static inline void tcg_gen_rem_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_helper64(tcg_helper_rem_i64, ret, arg1, arg2); -} - -static inline void tcg_gen_divu_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_helper64(tcg_helper_divu_i64, ret, arg1, arg2); -} - -static inline void tcg_gen_remu_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_helper64(tcg_helper_remu_i64, ret, arg1, arg2); -} - -#else - -static inline void tcg_gen_mov_i64(TCGv_i64 ret, TCGv_i64 arg) -{ - if (!TCGV_EQUAL_I64(ret, arg)) - tcg_gen_op2_i64(INDEX_op_mov_i64, ret, arg); -} - -static inline void tcg_gen_movi_i64(TCGv_i64 ret, int64_t arg) -{ - tcg_gen_op2i_i64(INDEX_op_movi_i64, ret, arg); -} - -static inline void tcg_gen_ld8u_i64(TCGv_i64 ret, TCGv_i64 arg2, - tcg_target_long offset) -{ - tcg_gen_ldst_op_i64(INDEX_op_ld8u_i64, ret, arg2, offset); -} - -static inline void tcg_gen_ld8s_i64(TCGv_i64 ret, TCGv_i64 arg2, - tcg_target_long offset) -{ - tcg_gen_ldst_op_i64(INDEX_op_ld8s_i64, ret, arg2, offset); -} - -static inline void tcg_gen_ld16u_i64(TCGv_i64 ret, TCGv_i64 arg2, - tcg_target_long offset) -{ - tcg_gen_ldst_op_i64(INDEX_op_ld16u_i64, ret, arg2, offset); -} - -static inline void tcg_gen_ld16s_i64(TCGv_i64 ret, TCGv_i64 arg2, - tcg_target_long offset) -{ - tcg_gen_ldst_op_i64(INDEX_op_ld16s_i64, ret, arg2, offset); -} - -static inline void tcg_gen_ld32u_i64(TCGv_i64 ret, TCGv_i64 arg2, - tcg_target_long offset) -{ - tcg_gen_ldst_op_i64(INDEX_op_ld32u_i64, ret, arg2, offset); -} - -static inline void tcg_gen_ld32s_i64(TCGv_i64 ret, TCGv_i64 arg2, - tcg_target_long offset) -{ - tcg_gen_ldst_op_i64(INDEX_op_ld32s_i64, ret, arg2, offset); -} - -static inline void tcg_gen_ld_i64(TCGv_i64 ret, TCGv_i64 arg2, tcg_target_long offset) -{ - tcg_gen_ldst_op_i64(INDEX_op_ld_i64, ret, arg2, offset); -} - -static inline void tcg_gen_st8_i64(TCGv_i64 arg1, TCGv_i64 arg2, - tcg_target_long offset) -{ - tcg_gen_ldst_op_i64(INDEX_op_st8_i64, arg1, arg2, offset); -} - -static inline void tcg_gen_st16_i64(TCGv_i64 arg1, TCGv_i64 arg2, - tcg_target_long offset) -{ - tcg_gen_ldst_op_i64(INDEX_op_st16_i64, arg1, arg2, offset); -} - -static inline void tcg_gen_st32_i64(TCGv_i64 arg1, TCGv_i64 arg2, - tcg_target_long offset) -{ - tcg_gen_ldst_op_i64(INDEX_op_st32_i64, arg1, arg2, offset); -} - -static inline void tcg_gen_st_i64(TCGv_i64 arg1, TCGv_i64 arg2, tcg_target_long offset) -{ - tcg_gen_ldst_op_i64(INDEX_op_st_i64, arg1, arg2, offset); -} - -static inline void tcg_gen_add_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_op3_i64(INDEX_op_add_i64, ret, arg1, arg2); -} - -static inline void tcg_gen_sub_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_op3_i64(INDEX_op_sub_i64, ret, arg1, arg2); -} - -static inline void tcg_gen_and_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - if (TCGV_EQUAL_I64(arg1, arg2)) { - tcg_gen_mov_i64(ret, arg1); - } else { - tcg_gen_op3_i64(INDEX_op_and_i64, ret, arg1, arg2); - } -} - -static inline void tcg_gen_andi_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2) -{ - TCGv_i64 t0 = tcg_const_i64(arg2); - tcg_gen_and_i64(ret, arg1, t0); - tcg_temp_free_i64(t0); -} - -static inline void tcg_gen_or_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - if (TCGV_EQUAL_I64(arg1, arg2)) { - tcg_gen_mov_i64(ret, arg1); - } else { - tcg_gen_op3_i64(INDEX_op_or_i64, ret, arg1, arg2); - } -} - -static inline void tcg_gen_ori_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2) -{ - TCGv_i64 t0 = tcg_const_i64(arg2); - tcg_gen_or_i64(ret, arg1, t0); - tcg_temp_free_i64(t0); -} - -static inline void tcg_gen_xor_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - if (TCGV_EQUAL_I64(arg1, arg2)) { - tcg_gen_movi_i64(ret, 0); - } else { - tcg_gen_op3_i64(INDEX_op_xor_i64, ret, arg1, arg2); - } -} - -static inline void tcg_gen_xori_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2) -{ - TCGv_i64 t0 = tcg_const_i64(arg2); - tcg_gen_xor_i64(ret, arg1, t0); - tcg_temp_free_i64(t0); -} - -static inline void tcg_gen_shl_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_op3_i64(INDEX_op_shl_i64, ret, arg1, arg2); -} - -static inline void tcg_gen_shli_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2) -{ - if (arg2 == 0) { - tcg_gen_mov_i64(ret, arg1); - } else { - TCGv_i64 t0 = tcg_const_i64(arg2); - tcg_gen_shl_i64(ret, arg1, t0); - tcg_temp_free_i64(t0); - } -} - -static inline void tcg_gen_shr_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_op3_i64(INDEX_op_shr_i64, ret, arg1, arg2); -} - -static inline void tcg_gen_shri_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2) -{ - if (arg2 == 0) { - tcg_gen_mov_i64(ret, arg1); - } else { - TCGv_i64 t0 = tcg_const_i64(arg2); - tcg_gen_shr_i64(ret, arg1, t0); - tcg_temp_free_i64(t0); - } -} - -static inline void tcg_gen_sar_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_op3_i64(INDEX_op_sar_i64, ret, arg1, arg2); -} - -static inline void tcg_gen_sari_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2) -{ - if (arg2 == 0) { - tcg_gen_mov_i64(ret, arg1); - } else { - TCGv_i64 t0 = tcg_const_i64(arg2); - tcg_gen_sar_i64(ret, arg1, t0); - tcg_temp_free_i64(t0); - } -} - -static inline void tcg_gen_brcond_i64(int cond, TCGv_i64 arg1, TCGv_i64 arg2, - int label_index) -{ - tcg_gen_op4ii_i64(INDEX_op_brcond_i64, arg1, arg2, cond, label_index); -} - -static inline void tcg_gen_mul_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_op3_i64(INDEX_op_mul_i64, ret, arg1, arg2); -} - -#ifdef TCG_TARGET_HAS_div_i64 -static inline void tcg_gen_div_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_op3_i64(INDEX_op_div_i64, ret, arg1, arg2); -} - -static inline void tcg_gen_rem_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_op3_i64(INDEX_op_rem_i64, ret, arg1, arg2); -} - -static inline void tcg_gen_divu_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_op3_i64(INDEX_op_divu_i64, ret, arg1, arg2); -} - -static inline void tcg_gen_remu_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_op3_i64(INDEX_op_remu_i64, ret, arg1, arg2); -} -#else -static inline void tcg_gen_div_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - TCGv_i64 t0; - t0 = tcg_temp_new_i64(); - tcg_gen_sari_i64(t0, arg1, 63); - tcg_gen_op5_i64(INDEX_op_div2_i64, ret, t0, arg1, t0, arg2); - tcg_temp_free_i64(t0); -} - -static inline void tcg_gen_rem_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - TCGv_i64 t0; - t0 = tcg_temp_new_i64(); - tcg_gen_sari_i64(t0, arg1, 63); - tcg_gen_op5_i64(INDEX_op_div2_i64, t0, ret, arg1, t0, arg2); - tcg_temp_free_i64(t0); -} - -static inline void tcg_gen_divu_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - TCGv_i64 t0; - t0 = tcg_temp_new_i64(); - tcg_gen_movi_i64(t0, 0); - tcg_gen_op5_i64(INDEX_op_divu2_i64, ret, t0, arg1, t0, arg2); - tcg_temp_free_i64(t0); -} - -static inline void tcg_gen_remu_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - TCGv_i64 t0; - t0 = tcg_temp_new_i64(); - tcg_gen_movi_i64(t0, 0); - tcg_gen_op5_i64(INDEX_op_divu2_i64, t0, ret, arg1, t0, arg2); - tcg_temp_free_i64(t0); -} -#endif - -#endif - -static inline void tcg_gen_addi_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2) -{ - /* some cases can be optimized here */ - if (arg2 == 0) { - tcg_gen_mov_i64(ret, arg1); - } else { - TCGv_i64 t0 = tcg_const_i64(arg2); - tcg_gen_add_i64(ret, arg1, t0); - tcg_temp_free_i64(t0); - } -} - -static inline void tcg_gen_subfi_i64(TCGv_i64 ret, int64_t arg1, TCGv_i64 arg2) -{ - TCGv_i64 t0 = tcg_const_i64(arg1); - tcg_gen_sub_i64(ret, t0, arg2); - tcg_temp_free_i64(t0); -} - -static inline void tcg_gen_subi_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2) -{ - /* some cases can be optimized here */ - if (arg2 == 0) { - tcg_gen_mov_i64(ret, arg1); - } else { - TCGv_i64 t0 = tcg_const_i64(arg2); - tcg_gen_sub_i64(ret, arg1, t0); - tcg_temp_free_i64(t0); - } -} -static inline void tcg_gen_brcondi_i64(int cond, TCGv_i64 arg1, int64_t arg2, - int label_index) -{ - TCGv_i64 t0 = tcg_const_i64(arg2); - tcg_gen_brcond_i64(cond, arg1, t0, label_index); - tcg_temp_free_i64(t0); -} - -static inline void tcg_gen_muli_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2) -{ - TCGv_i64 t0 = tcg_const_i64(arg2); - tcg_gen_mul_i64(ret, arg1, t0); - tcg_temp_free_i64(t0); -} - - -/***************************************/ -/* optional operations */ - -static inline void tcg_gen_ext8s_i32(TCGv_i32 ret, TCGv_i32 arg) -{ -#ifdef TCG_TARGET_HAS_ext8s_i32 - tcg_gen_op2_i32(INDEX_op_ext8s_i32, ret, arg); -#else - tcg_gen_shli_i32(ret, arg, 24); - tcg_gen_sari_i32(ret, ret, 24); -#endif -} - -static inline void tcg_gen_ext16s_i32(TCGv_i32 ret, TCGv_i32 arg) -{ -#ifdef TCG_TARGET_HAS_ext16s_i32 - tcg_gen_op2_i32(INDEX_op_ext16s_i32, ret, arg); -#else - tcg_gen_shli_i32(ret, arg, 16); - tcg_gen_sari_i32(ret, ret, 16); -#endif -} - -static inline void tcg_gen_ext8u_i32(TCGv_i32 ret, TCGv_i32 arg) -{ -#ifdef TCG_TARGET_HAS_ext8u_i32 - tcg_gen_op2_i32(INDEX_op_ext8u_i32, ret, arg); -#else - tcg_gen_andi_i32(ret, arg, 0xffu); -#endif -} - -static inline void tcg_gen_ext16u_i32(TCGv_i32 ret, TCGv_i32 arg) -{ -#ifdef TCG_TARGET_HAS_ext16u_i32 - tcg_gen_op2_i32(INDEX_op_ext16u_i32, ret, arg); -#else - tcg_gen_andi_i32(ret, arg, 0xffffu); -#endif -} - -/* Note: we assume the two high bytes are set to zero */ -static inline void tcg_gen_bswap16_i32(TCGv_i32 ret, TCGv_i32 arg) -{ -#ifdef TCG_TARGET_HAS_bswap16_i32 - tcg_gen_op2_i32(INDEX_op_bswap16_i32, ret, arg); -#else - TCGv_i32 t0 = tcg_temp_new_i32(); - - tcg_gen_ext8u_i32(t0, arg); - tcg_gen_shli_i32(t0, t0, 8); - tcg_gen_shri_i32(ret, arg, 8); - tcg_gen_or_i32(ret, ret, t0); - tcg_temp_free_i32(t0); -#endif -} - -static inline void tcg_gen_bswap32_i32(TCGv_i32 ret, TCGv_i32 arg) -{ -#ifdef TCG_TARGET_HAS_bswap32_i32 - tcg_gen_op2_i32(INDEX_op_bswap32_i32, ret, arg); -#else - TCGv_i32 t0, t1; - t0 = tcg_temp_new_i32(); - t1 = tcg_temp_new_i32(); - - tcg_gen_shli_i32(t0, arg, 24); - - tcg_gen_andi_i32(t1, arg, 0x0000ff00); - tcg_gen_shli_i32(t1, t1, 8); - tcg_gen_or_i32(t0, t0, t1); - - tcg_gen_shri_i32(t1, arg, 8); - tcg_gen_andi_i32(t1, t1, 0x0000ff00); - tcg_gen_or_i32(t0, t0, t1); - - tcg_gen_shri_i32(t1, arg, 24); - tcg_gen_or_i32(ret, t0, t1); - tcg_temp_free_i32(t0); - tcg_temp_free_i32(t1); -#endif -} - -#if TCG_TARGET_REG_BITS == 32 -static inline void tcg_gen_ext8s_i64(TCGv_i64 ret, TCGv_i64 arg) -{ - tcg_gen_ext8s_i32(TCGV_LOW(ret), TCGV_LOW(arg)); - tcg_gen_sari_i32(TCGV_HIGH(ret), TCGV_LOW(ret), 31); -} - -static inline void tcg_gen_ext16s_i64(TCGv_i64 ret, TCGv_i64 arg) -{ - tcg_gen_ext16s_i32(TCGV_LOW(ret), TCGV_LOW(arg)); - tcg_gen_sari_i32(TCGV_HIGH(ret), TCGV_LOW(ret), 31); -} - -static inline void tcg_gen_ext32s_i64(TCGv_i64 ret, TCGv_i64 arg) -{ - tcg_gen_mov_i32(TCGV_LOW(ret), TCGV_LOW(arg)); - tcg_gen_sari_i32(TCGV_HIGH(ret), TCGV_LOW(ret), 31); -} - -static inline void tcg_gen_ext8u_i64(TCGv_i64 ret, TCGv_i64 arg) -{ - tcg_gen_ext8u_i32(TCGV_LOW(ret), TCGV_LOW(arg)); - tcg_gen_movi_i32(TCGV_HIGH(ret), 0); -} - -static inline void tcg_gen_ext16u_i64(TCGv_i64 ret, TCGv_i64 arg) -{ - tcg_gen_ext16u_i32(TCGV_LOW(ret), TCGV_LOW(arg)); - tcg_gen_movi_i32(TCGV_HIGH(ret), 0); -} - -static inline void tcg_gen_ext32u_i64(TCGv_i64 ret, TCGv_i64 arg) -{ - tcg_gen_mov_i32(TCGV_LOW(ret), TCGV_LOW(arg)); - tcg_gen_movi_i32(TCGV_HIGH(ret), 0); -} - -static inline void tcg_gen_trunc_i64_i32(TCGv_i32 ret, TCGv_i64 arg) -{ - tcg_gen_mov_i32(ret, TCGV_LOW(arg)); -} - -static inline void tcg_gen_extu_i32_i64(TCGv_i64 ret, TCGv_i32 arg) -{ - tcg_gen_mov_i32(TCGV_LOW(ret), arg); - tcg_gen_movi_i32(TCGV_HIGH(ret), 0); -} - -static inline void tcg_gen_ext_i32_i64(TCGv_i64 ret, TCGv_i32 arg) -{ - tcg_gen_mov_i32(TCGV_LOW(ret), arg); - tcg_gen_sari_i32(TCGV_HIGH(ret), TCGV_LOW(ret), 31); -} - -/* Note: we assume the six high bytes are set to zero */ -static inline void tcg_gen_bswap16_i64(TCGv_i64 ret, TCGv_i64 arg) -{ - tcg_gen_mov_i32(TCGV_HIGH(ret), TCGV_HIGH(arg)); - tcg_gen_bswap16_i32(TCGV_LOW(ret), TCGV_LOW(arg)); -} - -/* Note: we assume the four high bytes are set to zero */ -static inline void tcg_gen_bswap32_i64(TCGv_i64 ret, TCGv_i64 arg) -{ - tcg_gen_mov_i32(TCGV_HIGH(ret), TCGV_HIGH(arg)); - tcg_gen_bswap32_i32(TCGV_LOW(ret), TCGV_LOW(arg)); -} - -static inline void tcg_gen_bswap64_i64(TCGv_i64 ret, TCGv_i64 arg) -{ - TCGv_i32 t0, t1; - t0 = tcg_temp_new_i32(); - t1 = tcg_temp_new_i32(); - - tcg_gen_bswap32_i32(t0, TCGV_LOW(arg)); - tcg_gen_bswap32_i32(t1, TCGV_HIGH(arg)); - tcg_gen_mov_i32(TCGV_LOW(ret), t1); - tcg_gen_mov_i32(TCGV_HIGH(ret), t0); - tcg_temp_free_i32(t0); - tcg_temp_free_i32(t1); -} -#else - -static inline void tcg_gen_ext8s_i64(TCGv_i64 ret, TCGv_i64 arg) -{ -#ifdef TCG_TARGET_HAS_ext8s_i64 - tcg_gen_op2_i64(INDEX_op_ext8s_i64, ret, arg); -#else - tcg_gen_shli_i64(ret, arg, 56); - tcg_gen_sari_i64(ret, ret, 56); -#endif -} - -static inline void tcg_gen_ext16s_i64(TCGv_i64 ret, TCGv_i64 arg) -{ -#ifdef TCG_TARGET_HAS_ext16s_i64 - tcg_gen_op2_i64(INDEX_op_ext16s_i64, ret, arg); -#else - tcg_gen_shli_i64(ret, arg, 48); - tcg_gen_sari_i64(ret, ret, 48); -#endif -} - -static inline void tcg_gen_ext32s_i64(TCGv_i64 ret, TCGv_i64 arg) -{ -#ifdef TCG_TARGET_HAS_ext32s_i64 - tcg_gen_op2_i64(INDEX_op_ext32s_i64, ret, arg); -#else - tcg_gen_shli_i64(ret, arg, 32); - tcg_gen_sari_i64(ret, ret, 32); -#endif -} - -static inline void tcg_gen_ext8u_i64(TCGv_i64 ret, TCGv_i64 arg) -{ -#ifdef TCG_TARGET_HAS_ext8u_i64 - tcg_gen_op2_i64(INDEX_op_ext8u_i64, ret, arg); -#else - tcg_gen_andi_i64(ret, arg, 0xffu); -#endif -} - -static inline void tcg_gen_ext16u_i64(TCGv_i64 ret, TCGv_i64 arg) -{ -#ifdef TCG_TARGET_HAS_ext16u_i64 - tcg_gen_op2_i64(INDEX_op_ext16u_i64, ret, arg); -#else - tcg_gen_andi_i64(ret, arg, 0xffffu); -#endif -} - -static inline void tcg_gen_ext32u_i64(TCGv_i64 ret, TCGv_i64 arg) -{ -#ifdef TCG_TARGET_HAS_ext32u_i64 - tcg_gen_op2_i64(INDEX_op_ext32u_i64, ret, arg); -#else - tcg_gen_andi_i64(ret, arg, 0xffffffffu); -#endif -} - -/* Note: we assume the target supports move between 32 and 64 bit - registers. This will probably break MIPS64 targets. */ -static inline void tcg_gen_trunc_i64_i32(TCGv_i32 ret, TCGv_i64 arg) -{ - tcg_gen_mov_i32(ret, MAKE_TCGV_I32(GET_TCGV_I64(arg))); -} - -/* Note: we assume the target supports move between 32 and 64 bit - registers */ -static inline void tcg_gen_extu_i32_i64(TCGv_i64 ret, TCGv_i32 arg) -{ - tcg_gen_ext32u_i64(ret, MAKE_TCGV_I64(GET_TCGV_I32(arg))); -} - -/* Note: we assume the target supports move between 32 and 64 bit - registers */ -static inline void tcg_gen_ext_i32_i64(TCGv_i64 ret, TCGv_i32 arg) -{ - tcg_gen_ext32s_i64(ret, MAKE_TCGV_I64(GET_TCGV_I32(arg))); -} - -/* Note: we assume the six high bytes are set to zero */ -static inline void tcg_gen_bswap16_i64(TCGv_i64 ret, TCGv_i64 arg) -{ -#ifdef TCG_TARGET_HAS_bswap16_i64 - tcg_gen_op2_i64(INDEX_op_bswap16_i64, ret, arg); -#else - TCGv_i64 t0 = tcg_temp_new_i64(); - - tcg_gen_ext8u_i64(t0, arg); - tcg_gen_shli_i64(t0, t0, 8); - tcg_gen_shri_i64(ret, arg, 8); - tcg_gen_or_i64(ret, ret, t0); - tcg_temp_free_i64(t0); -#endif -} - -/* Note: we assume the four high bytes are set to zero */ -static inline void tcg_gen_bswap32_i64(TCGv_i64 ret, TCGv_i64 arg) -{ -#ifdef TCG_TARGET_HAS_bswap32_i64 - tcg_gen_op2_i64(INDEX_op_bswap32_i64, ret, arg); -#else - TCGv_i64 t0, t1; - t0 = tcg_temp_new_i64(); - t1 = tcg_temp_new_i64(); - - tcg_gen_shli_i64(t0, arg, 24); - tcg_gen_ext32u_i64(t0, t0); - - tcg_gen_andi_i64(t1, arg, 0x0000ff00); - tcg_gen_shli_i64(t1, t1, 8); - tcg_gen_or_i64(t0, t0, t1); - - tcg_gen_shri_i64(t1, arg, 8); - tcg_gen_andi_i64(t1, t1, 0x0000ff00); - tcg_gen_or_i64(t0, t0, t1); - - tcg_gen_shri_i64(t1, arg, 24); - tcg_gen_or_i64(ret, t0, t1); - tcg_temp_free_i64(t0); - tcg_temp_free_i64(t1); -#endif -} - -static inline void tcg_gen_bswap64_i64(TCGv_i64 ret, TCGv_i64 arg) -{ -#ifdef TCG_TARGET_HAS_bswap64_i64 - tcg_gen_op2_i64(INDEX_op_bswap64_i64, ret, arg); -#else - TCGv_i64 t0 = tcg_temp_new_i64(); - TCGv_i64 t1 = tcg_temp_new_i64(); - - tcg_gen_shli_i64(t0, arg, 56); - - tcg_gen_andi_i64(t1, arg, 0x0000ff00); - tcg_gen_shli_i64(t1, t1, 40); - tcg_gen_or_i64(t0, t0, t1); - - tcg_gen_andi_i64(t1, arg, 0x00ff0000); - tcg_gen_shli_i64(t1, t1, 24); - tcg_gen_or_i64(t0, t0, t1); - - tcg_gen_andi_i64(t1, arg, 0xff000000); - tcg_gen_shli_i64(t1, t1, 8); - tcg_gen_or_i64(t0, t0, t1); - - tcg_gen_shri_i64(t1, arg, 8); - tcg_gen_andi_i64(t1, t1, 0xff000000); - tcg_gen_or_i64(t0, t0, t1); - - tcg_gen_shri_i64(t1, arg, 24); - tcg_gen_andi_i64(t1, t1, 0x00ff0000); - tcg_gen_or_i64(t0, t0, t1); - - tcg_gen_shri_i64(t1, arg, 40); - tcg_gen_andi_i64(t1, t1, 0x0000ff00); - tcg_gen_or_i64(t0, t0, t1); - - tcg_gen_shri_i64(t1, arg, 56); - tcg_gen_or_i64(ret, t0, t1); - tcg_temp_free_i64(t0); - tcg_temp_free_i64(t1); -#endif -} - -#endif - -static inline void tcg_gen_neg_i32(TCGv_i32 ret, TCGv_i32 arg) -{ -#ifdef TCG_TARGET_HAS_neg_i32 - tcg_gen_op2_i32(INDEX_op_neg_i32, ret, arg); -#else - TCGv_i32 t0 = tcg_const_i32(0); - tcg_gen_sub_i32(ret, t0, arg); - tcg_temp_free_i32(t0); -#endif -} - -static inline void tcg_gen_neg_i64(TCGv_i64 ret, TCGv_i64 arg) -{ -#ifdef TCG_TARGET_HAS_neg_i64 - tcg_gen_op2_i64(INDEX_op_neg_i64, ret, arg); -#else - TCGv_i64 t0 = tcg_const_i64(0); - tcg_gen_sub_i64(ret, t0, arg); - tcg_temp_free_i64(t0); -#endif -} - -static inline void tcg_gen_not_i32(TCGv_i32 ret, TCGv_i32 arg) -{ -#ifdef TCG_TARGET_HAS_not_i32 - tcg_gen_op2_i32(INDEX_op_not_i32, ret, arg); -#else - tcg_gen_xori_i32(ret, arg, -1); -#endif -} - -static inline void tcg_gen_not_i64(TCGv_i64 ret, TCGv_i64 arg) -{ -#ifdef TCG_TARGET_HAS_not_i64 - tcg_gen_op2_i64(INDEX_op_not_i64, ret, arg); -#else - tcg_gen_xori_i64(ret, arg, -1); -#endif -} - -static inline void tcg_gen_discard_i32(TCGv_i32 arg) -{ - tcg_gen_op1_i32(INDEX_op_discard, arg); -} - -#if TCG_TARGET_REG_BITS == 32 -static inline void tcg_gen_discard_i64(TCGv_i64 arg) -{ - tcg_gen_discard_i32(TCGV_LOW(arg)); - tcg_gen_discard_i32(TCGV_HIGH(arg)); -} -#else -static inline void tcg_gen_discard_i64(TCGv_i64 arg) -{ - tcg_gen_op1_i64(INDEX_op_discard, arg); -} -#endif - -static inline void tcg_gen_concat_i32_i64(TCGv_i64 dest, TCGv_i32 low, TCGv_i32 high) -{ -#if TCG_TARGET_REG_BITS == 32 - tcg_gen_mov_i32(TCGV_LOW(dest), low); - tcg_gen_mov_i32(TCGV_HIGH(dest), high); -#else - TCGv_i64 tmp = tcg_temp_new_i64(); - /* This extension is only needed for type correctness. - We may be able to do better given target specific information. */ - tcg_gen_extu_i32_i64(tmp, high); - tcg_gen_shli_i64(tmp, tmp, 32); - tcg_gen_extu_i32_i64(dest, low); - tcg_gen_or_i64(dest, dest, tmp); - tcg_temp_free_i64(tmp); -#endif -} - -static inline void tcg_gen_concat32_i64(TCGv_i64 dest, TCGv_i64 low, TCGv_i64 high) -{ -#if TCG_TARGET_REG_BITS == 32 - tcg_gen_concat_i32_i64(dest, TCGV_LOW(low), TCGV_LOW(high)); -#else - TCGv_i64 tmp = tcg_temp_new_i64(); - tcg_gen_ext32u_i64(dest, low); - tcg_gen_shli_i64(tmp, high, 32); - tcg_gen_or_i64(dest, dest, tmp); - tcg_temp_free_i64(tmp); -#endif -} - -static inline void tcg_gen_andc_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - TCGv_i32 t0; - t0 = tcg_temp_new_i32(); - tcg_gen_not_i32(t0, arg2); - tcg_gen_and_i32(ret, arg1, t0); - tcg_temp_free_i32(t0); -} - -static inline void tcg_gen_andc_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - TCGv_i64 t0; - t0 = tcg_temp_new_i64(); - tcg_gen_not_i64(t0, arg2); - tcg_gen_and_i64(ret, arg1, t0); - tcg_temp_free_i64(t0); -} - -static inline void tcg_gen_eqv_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - tcg_gen_xor_i32(ret, arg1, arg2); - tcg_gen_not_i32(ret, ret); -} - -static inline void tcg_gen_eqv_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_xor_i64(ret, arg1, arg2); - tcg_gen_not_i64(ret, ret); -} - -static inline void tcg_gen_nand_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - tcg_gen_and_i32(ret, arg1, arg2); - tcg_gen_not_i32(ret, ret); -} - -static inline void tcg_gen_nand_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_and_i64(ret, arg1, arg2); - tcg_gen_not_i64(ret, ret); -} - -static inline void tcg_gen_nor_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - tcg_gen_or_i32(ret, arg1, arg2); - tcg_gen_not_i32(ret, ret); -} - -static inline void tcg_gen_nor_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - tcg_gen_or_i64(ret, arg1, arg2); - tcg_gen_not_i64(ret, ret); -} - -static inline void tcg_gen_orc_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ - TCGv_i32 t0; - t0 = tcg_temp_new_i32(); - tcg_gen_not_i32(t0, arg2); - tcg_gen_or_i32(ret, arg1, t0); - tcg_temp_free_i32(t0); -} - -static inline void tcg_gen_orc_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ - TCGv_i64 t0; - t0 = tcg_temp_new_i64(); - tcg_gen_not_i64(t0, arg2); - tcg_gen_or_i64(ret, arg1, t0); - tcg_temp_free_i64(t0); -} - -static inline void tcg_gen_rotl_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ -#ifdef TCG_TARGET_HAS_rot_i32 - tcg_gen_op3_i32(INDEX_op_rotl_i32, ret, arg1, arg2); -#else - TCGv_i32 t0, t1; - - t0 = tcg_temp_new_i32(); - t1 = tcg_temp_new_i32(); - tcg_gen_shl_i32(t0, arg1, arg2); - tcg_gen_subfi_i32(t1, 32, arg2); - tcg_gen_shr_i32(t1, arg1, t1); - tcg_gen_or_i32(ret, t0, t1); - tcg_temp_free_i32(t0); - tcg_temp_free_i32(t1); -#endif -} - -static inline void tcg_gen_rotl_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ -#ifdef TCG_TARGET_HAS_rot_i64 - tcg_gen_op3_i64(INDEX_op_rotl_i64, ret, arg1, arg2); -#else - TCGv_i64 t0, t1; - - t0 = tcg_temp_new_i64(); - t1 = tcg_temp_new_i64(); - tcg_gen_shl_i64(t0, arg1, arg2); - tcg_gen_subfi_i64(t1, 64, arg2); - tcg_gen_shr_i64(t1, arg1, t1); - tcg_gen_or_i64(ret, t0, t1); - tcg_temp_free_i64(t0); - tcg_temp_free_i64(t1); -#endif -} - -static inline void tcg_gen_rotli_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2) -{ - /* some cases can be optimized here */ - if (arg2 == 0) { - tcg_gen_mov_i32(ret, arg1); - } else { -#ifdef TCG_TARGET_HAS_rot_i32 - TCGv_i32 t0 = tcg_const_i32(arg2); - tcg_gen_rotl_i32(ret, arg1, t0); - tcg_temp_free_i32(t0); -#else - TCGv_i32 t0, t1; - t0 = tcg_temp_new_i32(); - t1 = tcg_temp_new_i32(); - tcg_gen_shli_i32(t0, arg1, arg2); - tcg_gen_shri_i32(t1, arg1, 32 - arg2); - tcg_gen_or_i32(ret, t0, t1); - tcg_temp_free_i32(t0); - tcg_temp_free_i32(t1); -#endif - } -} - -static inline void tcg_gen_rotli_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2) -{ - /* some cases can be optimized here */ - if (arg2 == 0) { - tcg_gen_mov_i64(ret, arg1); - } else { -#ifdef TCG_TARGET_HAS_rot_i64 - TCGv_i64 t0 = tcg_const_i64(arg2); - tcg_gen_rotl_i64(ret, arg1, t0); - tcg_temp_free_i64(t0); -#else - TCGv_i64 t0, t1; - t0 = tcg_temp_new_i64(); - t1 = tcg_temp_new_i64(); - tcg_gen_shli_i64(t0, arg1, arg2); - tcg_gen_shri_i64(t1, arg1, 64 - arg2); - tcg_gen_or_i64(ret, t0, t1); - tcg_temp_free_i64(t0); - tcg_temp_free_i64(t1); -#endif - } -} - -static inline void tcg_gen_rotr_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) -{ -#ifdef TCG_TARGET_HAS_rot_i32 - tcg_gen_op3_i32(INDEX_op_rotr_i32, ret, arg1, arg2); -#else - TCGv_i32 t0, t1; - - t0 = tcg_temp_new_i32(); - t1 = tcg_temp_new_i32(); - tcg_gen_shr_i32(t0, arg1, arg2); - tcg_gen_subfi_i32(t1, 32, arg2); - tcg_gen_shl_i32(t1, arg1, t1); - tcg_gen_or_i32(ret, t0, t1); - tcg_temp_free_i32(t0); - tcg_temp_free_i32(t1); -#endif -} - -static inline void tcg_gen_rotr_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2) -{ -#ifdef TCG_TARGET_HAS_rot_i64 - tcg_gen_op3_i64(INDEX_op_rotr_i64, ret, arg1, arg2); -#else - TCGv_i64 t0, t1; - - t0 = tcg_temp_new_i64(); - t1 = tcg_temp_new_i64(); - tcg_gen_shr_i64(t0, arg1, arg2); - tcg_gen_subfi_i64(t1, 64, arg2); - tcg_gen_shl_i64(t1, arg1, t1); - tcg_gen_or_i64(ret, t0, t1); - tcg_temp_free_i64(t0); - tcg_temp_free_i64(t1); -#endif -} - -static inline void tcg_gen_rotri_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2) -{ - /* some cases can be optimized here */ - if (arg2 == 0) { - tcg_gen_mov_i32(ret, arg1); - } else { - tcg_gen_rotli_i32(ret, arg1, 32 - arg2); - } -} - -static inline void tcg_gen_rotri_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2) -{ - /* some cases can be optimized here */ - if (arg2 == 0) { - tcg_gen_mov_i64(ret, arg1); - } else { - tcg_gen_rotli_i64(ret, arg1, 64 - arg2); - } -} - -/***************************************/ -/* QEMU specific operations. Their type depend on the QEMU CPU - type. */ -#ifndef TARGET_LONG_BITS -#error must include QEMU headers -#endif - -#if TARGET_LONG_BITS == 32 -#define TCGv TCGv_i32 -#define tcg_temp_new() tcg_temp_new_i32() -#define tcg_global_reg_new tcg_global_reg_new_i32 -#define tcg_global_mem_new tcg_global_mem_new_i32 -#define tcg_temp_local_new() tcg_temp_local_new_i32() -#define tcg_temp_free tcg_temp_free_i32 -#define tcg_gen_qemu_ldst_op tcg_gen_op3i_i32 -#define tcg_gen_qemu_ldst_op_i64 tcg_gen_qemu_ldst_op_i64_i32 -#define TCGV_UNUSED(x) TCGV_UNUSED_I32(x) -#define TCGV_EQUAL(a, b) TCGV_EQUAL_I32(a, b) -#else -#define TCGv TCGv_i64 -#define tcg_temp_new() tcg_temp_new_i64() -#define tcg_global_reg_new tcg_global_reg_new_i64 -#define tcg_global_mem_new tcg_global_mem_new_i64 -#define tcg_temp_local_new() tcg_temp_local_new_i64() -#define tcg_temp_free tcg_temp_free_i64 -#define tcg_gen_qemu_ldst_op tcg_gen_op3i_i64 -#define tcg_gen_qemu_ldst_op_i64 tcg_gen_qemu_ldst_op_i64_i64 -#define TCGV_UNUSED(x) TCGV_UNUSED_I64(x) -#define TCGV_EQUAL(a, b) TCGV_EQUAL_I64(a, b) -#endif - -/* debug info: write the PC of the corresponding QEMU CPU instruction */ -static inline void tcg_gen_debug_insn_start(uint64_t pc) -{ - /* XXX: must really use a 32 bit size for TCGArg in all cases */ -#if TARGET_LONG_BITS > TCG_TARGET_REG_BITS - tcg_gen_op2ii(INDEX_op_debug_insn_start, - (uint32_t)(pc), (uint32_t)(pc >> 32)); -#else - tcg_gen_op1i(INDEX_op_debug_insn_start, pc); -#endif -} - -static inline void tcg_gen_exit_tb(tcg_target_long val) -{ - tcg_gen_op1i(INDEX_op_exit_tb, val); -} - -static inline void tcg_gen_goto_tb(int idx) -{ - tcg_gen_op1i(INDEX_op_goto_tb, idx); -} - -#if TCG_TARGET_REG_BITS == 32 -static inline void tcg_gen_qemu_ld8u(TCGv ret, TCGv addr, int mem_index) -{ -#if TARGET_LONG_BITS == 32 - tcg_gen_op3i_i32(INDEX_op_qemu_ld8u, ret, addr, mem_index); -#else - tcg_gen_op4i_i32(INDEX_op_qemu_ld8u, TCGV_LOW(ret), TCGV_LOW(addr), - TCGV_HIGH(addr), mem_index); - tcg_gen_movi_i32(TCGV_HIGH(ret), 0); -#endif -} - -static inline void tcg_gen_qemu_ld8s(TCGv ret, TCGv addr, int mem_index) -{ -#if TARGET_LONG_BITS == 32 - tcg_gen_op3i_i32(INDEX_op_qemu_ld8s, ret, addr, mem_index); -#else - tcg_gen_op4i_i32(INDEX_op_qemu_ld8s, TCGV_LOW(ret), TCGV_LOW(addr), - TCGV_HIGH(addr), mem_index); - tcg_gen_sari_i32(TCGV_HIGH(ret), TCGV_LOW(ret), 31); -#endif -} - -static inline void tcg_gen_qemu_ld16u(TCGv ret, TCGv addr, int mem_index) -{ -#if TARGET_LONG_BITS == 32 - tcg_gen_op3i_i32(INDEX_op_qemu_ld16u, ret, addr, mem_index); -#else - tcg_gen_op4i_i32(INDEX_op_qemu_ld16u, TCGV_LOW(ret), TCGV_LOW(addr), - TCGV_HIGH(addr), mem_index); - tcg_gen_movi_i32(TCGV_HIGH(ret), 0); -#endif -} - -static inline void tcg_gen_qemu_ld16s(TCGv ret, TCGv addr, int mem_index) -{ -#if TARGET_LONG_BITS == 32 - tcg_gen_op3i_i32(INDEX_op_qemu_ld16s, ret, addr, mem_index); -#else - tcg_gen_op4i_i32(INDEX_op_qemu_ld16s, TCGV_LOW(ret), TCGV_LOW(addr), - TCGV_HIGH(addr), mem_index); - tcg_gen_sari_i32(TCGV_HIGH(ret), TCGV_LOW(ret), 31); -#endif -} - -static inline void tcg_gen_qemu_ld32u(TCGv ret, TCGv addr, int mem_index) -{ -#if TARGET_LONG_BITS == 32 - tcg_gen_op3i_i32(INDEX_op_qemu_ld32u, ret, addr, mem_index); -#else - tcg_gen_op4i_i32(INDEX_op_qemu_ld32u, TCGV_LOW(ret), TCGV_LOW(addr), - TCGV_HIGH(addr), mem_index); - tcg_gen_movi_i32(TCGV_HIGH(ret), 0); -#endif -} - -static inline void tcg_gen_qemu_ld32s(TCGv ret, TCGv addr, int mem_index) -{ -#if TARGET_LONG_BITS == 32 - tcg_gen_op3i_i32(INDEX_op_qemu_ld32u, ret, addr, mem_index); -#else - tcg_gen_op4i_i32(INDEX_op_qemu_ld32u, TCGV_LOW(ret), TCGV_LOW(addr), - TCGV_HIGH(addr), mem_index); - tcg_gen_sari_i32(TCGV_HIGH(ret), TCGV_LOW(ret), 31); -#endif -} - -static inline void tcg_gen_qemu_ld64(TCGv_i64 ret, TCGv addr, int mem_index) -{ -#if TARGET_LONG_BITS == 32 - tcg_gen_op4i_i32(INDEX_op_qemu_ld64, TCGV_LOW(ret), TCGV_HIGH(ret), addr, mem_index); -#else - tcg_gen_op5i_i32(INDEX_op_qemu_ld64, TCGV_LOW(ret), TCGV_HIGH(ret), - TCGV_LOW(addr), TCGV_HIGH(addr), mem_index); -#endif -} - -static inline void tcg_gen_qemu_st8(TCGv arg, TCGv addr, int mem_index) -{ -#if TARGET_LONG_BITS == 32 - tcg_gen_op3i_i32(INDEX_op_qemu_st8, arg, addr, mem_index); -#else - tcg_gen_op4i_i32(INDEX_op_qemu_st8, TCGV_LOW(arg), TCGV_LOW(addr), - TCGV_HIGH(addr), mem_index); -#endif -} - -static inline void tcg_gen_qemu_st16(TCGv arg, TCGv addr, int mem_index) -{ -#if TARGET_LONG_BITS == 32 - tcg_gen_op3i_i32(INDEX_op_qemu_st16, arg, addr, mem_index); -#else - tcg_gen_op4i_i32(INDEX_op_qemu_st16, TCGV_LOW(arg), TCGV_LOW(addr), - TCGV_HIGH(addr), mem_index); -#endif -} - -static inline void tcg_gen_qemu_st32(TCGv arg, TCGv addr, int mem_index) -{ -#if TARGET_LONG_BITS == 32 - tcg_gen_op3i_i32(INDEX_op_qemu_st32, arg, addr, mem_index); -#else - tcg_gen_op4i_i32(INDEX_op_qemu_st32, TCGV_LOW(arg), TCGV_LOW(addr), - TCGV_HIGH(addr), mem_index); -#endif -} - -static inline void tcg_gen_qemu_st64(TCGv_i64 arg, TCGv addr, int mem_index) -{ -#if TARGET_LONG_BITS == 32 - tcg_gen_op4i_i32(INDEX_op_qemu_st64, TCGV_LOW(arg), TCGV_HIGH(arg), addr, - mem_index); -#else - tcg_gen_op5i_i32(INDEX_op_qemu_st64, TCGV_LOW(arg), TCGV_HIGH(arg), - TCGV_LOW(addr), TCGV_HIGH(addr), mem_index); -#endif -} - -#define tcg_gen_ld_ptr tcg_gen_ld_i32 -#define tcg_gen_discard_ptr tcg_gen_discard_i32 - -#else /* TCG_TARGET_REG_BITS == 32 */ - -static inline void tcg_gen_qemu_ld8u(TCGv ret, TCGv addr, int mem_index) -{ - tcg_gen_qemu_ldst_op(INDEX_op_qemu_ld8u, ret, addr, mem_index); -} - -static inline void tcg_gen_qemu_ld8s(TCGv ret, TCGv addr, int mem_index) -{ - tcg_gen_qemu_ldst_op(INDEX_op_qemu_ld8s, ret, addr, mem_index); -} - -static inline void tcg_gen_qemu_ld16u(TCGv ret, TCGv addr, int mem_index) -{ - tcg_gen_qemu_ldst_op(INDEX_op_qemu_ld16u, ret, addr, mem_index); -} - -static inline void tcg_gen_qemu_ld16s(TCGv ret, TCGv addr, int mem_index) -{ - tcg_gen_qemu_ldst_op(INDEX_op_qemu_ld16s, ret, addr, mem_index); -} - -static inline void tcg_gen_qemu_ld32u(TCGv ret, TCGv addr, int mem_index) -{ - tcg_gen_qemu_ldst_op(INDEX_op_qemu_ld32u, ret, addr, mem_index); -} - -static inline void tcg_gen_qemu_ld32s(TCGv ret, TCGv addr, int mem_index) -{ - tcg_gen_qemu_ldst_op(INDEX_op_qemu_ld32s, ret, addr, mem_index); -} - -static inline void tcg_gen_qemu_ld64(TCGv_i64 ret, TCGv addr, int mem_index) -{ - tcg_gen_qemu_ldst_op_i64(INDEX_op_qemu_ld64, ret, addr, mem_index); -} - -static inline void tcg_gen_qemu_st8(TCGv arg, TCGv addr, int mem_index) -{ - tcg_gen_qemu_ldst_op(INDEX_op_qemu_st8, arg, addr, mem_index); -} - -static inline void tcg_gen_qemu_st16(TCGv arg, TCGv addr, int mem_index) -{ - tcg_gen_qemu_ldst_op(INDEX_op_qemu_st16, arg, addr, mem_index); -} - -static inline void tcg_gen_qemu_st32(TCGv arg, TCGv addr, int mem_index) -{ - tcg_gen_qemu_ldst_op(INDEX_op_qemu_st32, arg, addr, mem_index); -} - -static inline void tcg_gen_qemu_st64(TCGv_i64 arg, TCGv addr, int mem_index) -{ - tcg_gen_qemu_ldst_op_i64(INDEX_op_qemu_st64, arg, addr, mem_index); -} - -#define tcg_gen_ld_ptr tcg_gen_ld_i64 -#define tcg_gen_discard_ptr tcg_gen_discard_i64 - -#endif /* TCG_TARGET_REG_BITS != 32 */ - -#if TARGET_LONG_BITS == 64 -#define TCG_TYPE_TL TCG_TYPE_I64 -#define tcg_gen_movi_tl tcg_gen_movi_i64 -#define tcg_gen_mov_tl tcg_gen_mov_i64 -#define tcg_gen_ld8u_tl tcg_gen_ld8u_i64 -#define tcg_gen_ld8s_tl tcg_gen_ld8s_i64 -#define tcg_gen_ld16u_tl tcg_gen_ld16u_i64 -#define tcg_gen_ld16s_tl tcg_gen_ld16s_i64 -#define tcg_gen_ld32u_tl tcg_gen_ld32u_i64 -#define tcg_gen_ld32s_tl tcg_gen_ld32s_i64 -#define tcg_gen_ld_tl tcg_gen_ld_i64 -#define tcg_gen_st8_tl tcg_gen_st8_i64 -#define tcg_gen_st16_tl tcg_gen_st16_i64 -#define tcg_gen_st32_tl tcg_gen_st32_i64 -#define tcg_gen_st_tl tcg_gen_st_i64 -#define tcg_gen_add_tl tcg_gen_add_i64 -#define tcg_gen_addi_tl tcg_gen_addi_i64 -#define tcg_gen_sub_tl tcg_gen_sub_i64 -#define tcg_gen_neg_tl tcg_gen_neg_i64 -#define tcg_gen_subfi_tl tcg_gen_subfi_i64 -#define tcg_gen_subi_tl tcg_gen_subi_i64 -#define tcg_gen_and_tl tcg_gen_and_i64 -#define tcg_gen_andi_tl tcg_gen_andi_i64 -#define tcg_gen_or_tl tcg_gen_or_i64 -#define tcg_gen_ori_tl tcg_gen_ori_i64 -#define tcg_gen_xor_tl tcg_gen_xor_i64 -#define tcg_gen_xori_tl tcg_gen_xori_i64 -#define tcg_gen_not_tl tcg_gen_not_i64 -#define tcg_gen_shl_tl tcg_gen_shl_i64 -#define tcg_gen_shli_tl tcg_gen_shli_i64 -#define tcg_gen_shr_tl tcg_gen_shr_i64 -#define tcg_gen_shri_tl tcg_gen_shri_i64 -#define tcg_gen_sar_tl tcg_gen_sar_i64 -#define tcg_gen_sari_tl tcg_gen_sari_i64 -#define tcg_gen_brcond_tl tcg_gen_brcond_i64 -#define tcg_gen_brcondi_tl tcg_gen_brcondi_i64 -#define tcg_gen_mul_tl tcg_gen_mul_i64 -#define tcg_gen_muli_tl tcg_gen_muli_i64 -#define tcg_gen_div_tl tcg_gen_div_i64 -#define tcg_gen_rem_tl tcg_gen_rem_i64 -#define tcg_gen_divu_tl tcg_gen_divu_i64 -#define tcg_gen_remu_tl tcg_gen_remu_i64 -#define tcg_gen_discard_tl tcg_gen_discard_i64 -#define tcg_gen_trunc_tl_i32 tcg_gen_trunc_i64_i32 -#define tcg_gen_trunc_i64_tl tcg_gen_mov_i64 -#define tcg_gen_extu_i32_tl tcg_gen_extu_i32_i64 -#define tcg_gen_ext_i32_tl tcg_gen_ext_i32_i64 -#define tcg_gen_extu_tl_i64 tcg_gen_mov_i64 -#define tcg_gen_ext_tl_i64 tcg_gen_mov_i64 -#define tcg_gen_ext8u_tl tcg_gen_ext8u_i64 -#define tcg_gen_ext8s_tl tcg_gen_ext8s_i64 -#define tcg_gen_ext16u_tl tcg_gen_ext16u_i64 -#define tcg_gen_ext16s_tl tcg_gen_ext16s_i64 -#define tcg_gen_ext32u_tl tcg_gen_ext32u_i64 -#define tcg_gen_ext32s_tl tcg_gen_ext32s_i64 -#define tcg_gen_bswap16_tl tcg_gen_bswap16_i64 -#define tcg_gen_bswap32_tl tcg_gen_bswap32_i64 -#define tcg_gen_bswap64_tl tcg_gen_bswap64_i64 -#define tcg_gen_concat_tl_i64 tcg_gen_concat32_i64 -#define tcg_gen_andc_tl tcg_gen_andc_i64 -#define tcg_gen_eqv_tl tcg_gen_eqv_i64 -#define tcg_gen_nand_tl tcg_gen_nand_i64 -#define tcg_gen_nor_tl tcg_gen_nor_i64 -#define tcg_gen_orc_tl tcg_gen_orc_i64 -#define tcg_gen_rotl_tl tcg_gen_rotl_i64 -#define tcg_gen_rotli_tl tcg_gen_rotli_i64 -#define tcg_gen_rotr_tl tcg_gen_rotr_i64 -#define tcg_gen_rotri_tl tcg_gen_rotri_i64 -#define tcg_const_tl tcg_const_i64 -#define tcg_const_local_tl tcg_const_local_i64 -#else -#define TCG_TYPE_TL TCG_TYPE_I32 -#define tcg_gen_movi_tl tcg_gen_movi_i32 -#define tcg_gen_mov_tl tcg_gen_mov_i32 -#define tcg_gen_ld8u_tl tcg_gen_ld8u_i32 -#define tcg_gen_ld8s_tl tcg_gen_ld8s_i32 -#define tcg_gen_ld16u_tl tcg_gen_ld16u_i32 -#define tcg_gen_ld16s_tl tcg_gen_ld16s_i32 -#define tcg_gen_ld32u_tl tcg_gen_ld_i32 -#define tcg_gen_ld32s_tl tcg_gen_ld_i32 -#define tcg_gen_ld_tl tcg_gen_ld_i32 -#define tcg_gen_st8_tl tcg_gen_st8_i32 -#define tcg_gen_st16_tl tcg_gen_st16_i32 -#define tcg_gen_st32_tl tcg_gen_st_i32 -#define tcg_gen_st_tl tcg_gen_st_i32 -#define tcg_gen_add_tl tcg_gen_add_i32 -#define tcg_gen_addi_tl tcg_gen_addi_i32 -#define tcg_gen_sub_tl tcg_gen_sub_i32 -#define tcg_gen_neg_tl tcg_gen_neg_i32 -#define tcg_gen_subfi_tl tcg_gen_subfi_i32 -#define tcg_gen_subi_tl tcg_gen_subi_i32 -#define tcg_gen_and_tl tcg_gen_and_i32 -#define tcg_gen_andi_tl tcg_gen_andi_i32 -#define tcg_gen_or_tl tcg_gen_or_i32 -#define tcg_gen_ori_tl tcg_gen_ori_i32 -#define tcg_gen_xor_tl tcg_gen_xor_i32 -#define tcg_gen_xori_tl tcg_gen_xori_i32 -#define tcg_gen_not_tl tcg_gen_not_i32 -#define tcg_gen_shl_tl tcg_gen_shl_i32 -#define tcg_gen_shli_tl tcg_gen_shli_i32 -#define tcg_gen_shr_tl tcg_gen_shr_i32 -#define tcg_gen_shri_tl tcg_gen_shri_i32 -#define tcg_gen_sar_tl tcg_gen_sar_i32 -#define tcg_gen_sari_tl tcg_gen_sari_i32 -#define tcg_gen_brcond_tl tcg_gen_brcond_i32 -#define tcg_gen_brcondi_tl tcg_gen_brcondi_i32 -#define tcg_gen_mul_tl tcg_gen_mul_i32 -#define tcg_gen_muli_tl tcg_gen_muli_i32 -#define tcg_gen_div_tl tcg_gen_div_i32 -#define tcg_gen_rem_tl tcg_gen_rem_i32 -#define tcg_gen_divu_tl tcg_gen_divu_i32 -#define tcg_gen_remu_tl tcg_gen_remu_i32 -#define tcg_gen_discard_tl tcg_gen_discard_i32 -#define tcg_gen_trunc_tl_i32 tcg_gen_mov_i32 -#define tcg_gen_trunc_i64_tl tcg_gen_trunc_i64_i32 -#define tcg_gen_extu_i32_tl tcg_gen_mov_i32 -#define tcg_gen_ext_i32_tl tcg_gen_mov_i32 -#define tcg_gen_extu_tl_i64 tcg_gen_extu_i32_i64 -#define tcg_gen_ext_tl_i64 tcg_gen_ext_i32_i64 -#define tcg_gen_ext8u_tl tcg_gen_ext8u_i32 -#define tcg_gen_ext8s_tl tcg_gen_ext8s_i32 -#define tcg_gen_ext16u_tl tcg_gen_ext16u_i32 -#define tcg_gen_ext16s_tl tcg_gen_ext16s_i32 -#define tcg_gen_ext32u_tl tcg_gen_mov_i32 -#define tcg_gen_ext32s_tl tcg_gen_mov_i32 -#define tcg_gen_bswap16_tl tcg_gen_bswap16_i32 -#define tcg_gen_bswap32_tl tcg_gen_bswap32_i32 -#define tcg_gen_concat_tl_i64 tcg_gen_concat_i32_i64 -#define tcg_gen_andc_tl tcg_gen_andc_i32 -#define tcg_gen_eqv_tl tcg_gen_eqv_i32 -#define tcg_gen_nand_tl tcg_gen_nand_i32 -#define tcg_gen_nor_tl tcg_gen_nor_i32 -#define tcg_gen_orc_tl tcg_gen_orc_i32 -#define tcg_gen_rotl_tl tcg_gen_rotl_i32 -#define tcg_gen_rotli_tl tcg_gen_rotli_i32 -#define tcg_gen_rotr_tl tcg_gen_rotr_i32 -#define tcg_gen_rotri_tl tcg_gen_rotri_i32 -#define tcg_const_tl tcg_const_i32 -#define tcg_const_local_tl tcg_const_local_i32 -#endif - -#if TCG_TARGET_REG_BITS == 32 -#define tcg_gen_add_ptr tcg_gen_add_i32 -#define tcg_gen_addi_ptr tcg_gen_addi_i32 -#define tcg_gen_ext_i32_ptr tcg_gen_mov_i32 -#else /* TCG_TARGET_REG_BITS == 32 */ -#define tcg_gen_add_ptr tcg_gen_add_i64 -#define tcg_gen_addi_ptr tcg_gen_addi_i64 -#define tcg_gen_ext_i32_ptr tcg_gen_ext_i32_i64 -#endif /* TCG_TARGET_REG_BITS != 32 */ diff --git a/qemu/qemu-git/tcg/.svn/text-base/tcg-opc.h.svn-base b/qemu/qemu-git/tcg/.svn/text-base/tcg-opc.h.svn-base deleted file mode 100644 index b7f3fd7..0000000 --- a/qemu/qemu-git/tcg/.svn/text-base/tcg-opc.h.svn-base +++ /dev/null @@ -1,272 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2008 Fabrice Bellard - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ -#ifndef DEF2 -#define DEF2(name, oargs, iargs, cargs, flags) DEF(name, oargs + iargs + cargs, 0) -#endif - -/* predefined ops */ -DEF2(end, 0, 0, 0, 0) /* must be kept first */ -DEF2(nop, 0, 0, 0, 0) -DEF2(nop1, 0, 0, 1, 0) -DEF2(nop2, 0, 0, 2, 0) -DEF2(nop3, 0, 0, 3, 0) -DEF2(nopn, 0, 0, 1, 0) /* variable number of parameters */ - -DEF2(discard, 1, 0, 0, 0) - -DEF2(set_label, 0, 0, 1, 0) -DEF2(call, 0, 1, 2, TCG_OPF_SIDE_EFFECTS) /* variable number of parameters */ -DEF2(jmp, 0, 1, 0, TCG_OPF_BB_END | TCG_OPF_SIDE_EFFECTS) -DEF2(br, 0, 0, 1, TCG_OPF_BB_END | TCG_OPF_SIDE_EFFECTS) - -DEF2(mov_i32, 1, 1, 0, 0) -DEF2(movi_i32, 1, 0, 1, 0) -/* load/store */ -DEF2(ld8u_i32, 1, 1, 1, 0) -DEF2(ld8s_i32, 1, 1, 1, 0) -DEF2(ld16u_i32, 1, 1, 1, 0) -DEF2(ld16s_i32, 1, 1, 1, 0) -DEF2(ld_i32, 1, 1, 1, 0) -DEF2(st8_i32, 0, 2, 1, TCG_OPF_SIDE_EFFECTS) -DEF2(st16_i32, 0, 2, 1, TCG_OPF_SIDE_EFFECTS) -DEF2(st_i32, 0, 2, 1, TCG_OPF_SIDE_EFFECTS) -/* arith */ -DEF2(add_i32, 1, 2, 0, 0) -DEF2(sub_i32, 1, 2, 0, 0) -DEF2(mul_i32, 1, 2, 0, 0) -#ifdef TCG_TARGET_HAS_div_i32 -DEF2(div_i32, 1, 2, 0, 0) -DEF2(divu_i32, 1, 2, 0, 0) -DEF2(rem_i32, 1, 2, 0, 0) -DEF2(remu_i32, 1, 2, 0, 0) -#else -DEF2(div2_i32, 2, 3, 0, 0) -DEF2(divu2_i32, 2, 3, 0, 0) -#endif -DEF2(and_i32, 1, 2, 0, 0) -DEF2(or_i32, 1, 2, 0, 0) -DEF2(xor_i32, 1, 2, 0, 0) -/* shifts/rotates */ -DEF2(shl_i32, 1, 2, 0, 0) -DEF2(shr_i32, 1, 2, 0, 0) -DEF2(sar_i32, 1, 2, 0, 0) -#ifdef TCG_TARGET_HAS_rot_i32 -DEF2(rotl_i32, 1, 2, 0, 0) -DEF2(rotr_i32, 1, 2, 0, 0) -#endif - -DEF2(brcond_i32, 0, 2, 2, TCG_OPF_BB_END | TCG_OPF_SIDE_EFFECTS) -#if TCG_TARGET_REG_BITS == 32 -DEF2(add2_i32, 2, 4, 0, 0) -DEF2(sub2_i32, 2, 4, 0, 0) -DEF2(brcond2_i32, 0, 4, 2, TCG_OPF_BB_END | TCG_OPF_SIDE_EFFECTS) -DEF2(mulu2_i32, 2, 2, 0, 0) -#endif -#ifdef TCG_TARGET_HAS_ext8s_i32 -DEF2(ext8s_i32, 1, 1, 0, 0) -#endif -#ifdef TCG_TARGET_HAS_ext16s_i32 -DEF2(ext16s_i32, 1, 1, 0, 0) -#endif -#ifdef TCG_TARGET_HAS_ext8u_i32 -DEF2(ext8u_i32, 1, 1, 0, 0) -#endif -#ifdef TCG_TARGET_HAS_ext16u_i32 -DEF2(ext16u_i32, 1, 1, 0, 0) -#endif -#ifdef TCG_TARGET_HAS_bswap16_i32 -DEF2(bswap16_i32, 1, 1, 0, 0) -#endif -#ifdef TCG_TARGET_HAS_bswap32_i32 -DEF2(bswap32_i32, 1, 1, 0, 0) -#endif -#ifdef TCG_TARGET_HAS_not_i32 -DEF2(not_i32, 1, 1, 0, 0) -#endif -#ifdef TCG_TARGET_HAS_neg_i32 -DEF2(neg_i32, 1, 1, 0, 0) -#endif - -#if TCG_TARGET_REG_BITS == 64 -DEF2(mov_i64, 1, 1, 0, 0) -DEF2(movi_i64, 1, 0, 1, 0) -/* load/store */ -DEF2(ld8u_i64, 1, 1, 1, 0) -DEF2(ld8s_i64, 1, 1, 1, 0) -DEF2(ld16u_i64, 1, 1, 1, 0) -DEF2(ld16s_i64, 1, 1, 1, 0) -DEF2(ld32u_i64, 1, 1, 1, 0) -DEF2(ld32s_i64, 1, 1, 1, 0) -DEF2(ld_i64, 1, 1, 1, 0) -DEF2(st8_i64, 0, 2, 1, TCG_OPF_SIDE_EFFECTS) -DEF2(st16_i64, 0, 2, 1, TCG_OPF_SIDE_EFFECTS) -DEF2(st32_i64, 0, 2, 1, TCG_OPF_SIDE_EFFECTS) -DEF2(st_i64, 0, 2, 1, TCG_OPF_SIDE_EFFECTS) -/* arith */ -DEF2(add_i64, 1, 2, 0, 0) -DEF2(sub_i64, 1, 2, 0, 0) -DEF2(mul_i64, 1, 2, 0, 0) -#ifdef TCG_TARGET_HAS_div_i64 -DEF2(div_i64, 1, 2, 0, 0) -DEF2(divu_i64, 1, 2, 0, 0) -DEF2(rem_i64, 1, 2, 0, 0) -DEF2(remu_i64, 1, 2, 0, 0) -#else -DEF2(div2_i64, 2, 3, 0, 0) -DEF2(divu2_i64, 2, 3, 0, 0) -#endif -DEF2(and_i64, 1, 2, 0, 0) -DEF2(or_i64, 1, 2, 0, 0) -DEF2(xor_i64, 1, 2, 0, 0) -/* shifts/rotates */ -DEF2(shl_i64, 1, 2, 0, 0) -DEF2(shr_i64, 1, 2, 0, 0) -DEF2(sar_i64, 1, 2, 0, 0) -#ifdef TCG_TARGET_HAS_rot_i64 -DEF2(rotl_i64, 1, 2, 0, 0) -DEF2(rotr_i64, 1, 2, 0, 0) -#endif - -DEF2(brcond_i64, 0, 2, 2, TCG_OPF_BB_END | TCG_OPF_SIDE_EFFECTS) -#ifdef TCG_TARGET_HAS_ext8s_i64 -DEF2(ext8s_i64, 1, 1, 0, 0) -#endif -#ifdef TCG_TARGET_HAS_ext16s_i64 -DEF2(ext16s_i64, 1, 1, 0, 0) -#endif -#ifdef TCG_TARGET_HAS_ext32s_i64 -DEF2(ext32s_i64, 1, 1, 0, 0) -#endif -#ifdef TCG_TARGET_HAS_ext8u_i64 -DEF2(ext8u_i64, 1, 1, 0, 0) -#endif -#ifdef TCG_TARGET_HAS_ext16u_i64 -DEF2(ext16u_i64, 1, 1, 0, 0) -#endif -#ifdef TCG_TARGET_HAS_ext32u_i64 -DEF2(ext32u_i64, 1, 1, 0, 0) -#endif -#ifdef TCG_TARGET_HAS_bswap16_i64 -DEF2(bswap16_i64, 1, 1, 0, 0) -#endif -#ifdef TCG_TARGET_HAS_bswap32_i64 -DEF2(bswap32_i64, 1, 1, 0, 0) -#endif -#ifdef TCG_TARGET_HAS_bswap64_i64 -DEF2(bswap64_i64, 1, 1, 0, 0) -#endif -#ifdef TCG_TARGET_HAS_not_i64 -DEF2(not_i64, 1, 1, 0, 0) -#endif -#ifdef TCG_TARGET_HAS_neg_i64 -DEF2(neg_i64, 1, 1, 0, 0) -#endif -#endif - -/* QEMU specific */ -#if TARGET_LONG_BITS > TCG_TARGET_REG_BITS -DEF2(debug_insn_start, 0, 0, 2, 0) -#else -DEF2(debug_insn_start, 0, 0, 1, 0) -#endif -DEF2(exit_tb, 0, 0, 1, TCG_OPF_BB_END | TCG_OPF_SIDE_EFFECTS) -DEF2(goto_tb, 0, 0, 1, TCG_OPF_BB_END | TCG_OPF_SIDE_EFFECTS) -/* Note: even if TARGET_LONG_BITS is not defined, the INDEX_op - constants must be defined */ -#if TCG_TARGET_REG_BITS == 32 -#if TARGET_LONG_BITS == 32 -DEF2(qemu_ld8u, 1, 1, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#else -DEF2(qemu_ld8u, 1, 2, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#endif -#if TARGET_LONG_BITS == 32 -DEF2(qemu_ld8s, 1, 1, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#else -DEF2(qemu_ld8s, 1, 2, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#endif -#if TARGET_LONG_BITS == 32 -DEF2(qemu_ld16u, 1, 1, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#else -DEF2(qemu_ld16u, 1, 2, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#endif -#if TARGET_LONG_BITS == 32 -DEF2(qemu_ld16s, 1, 1, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#else -DEF2(qemu_ld16s, 1, 2, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#endif -#if TARGET_LONG_BITS == 32 -DEF2(qemu_ld32u, 1, 1, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#else -DEF2(qemu_ld32u, 1, 2, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#endif -#if TARGET_LONG_BITS == 32 -DEF2(qemu_ld32s, 1, 1, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#else -DEF2(qemu_ld32s, 1, 2, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#endif -#if TARGET_LONG_BITS == 32 -DEF2(qemu_ld64, 2, 1, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#else -DEF2(qemu_ld64, 2, 2, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#endif - -#if TARGET_LONG_BITS == 32 -DEF2(qemu_st8, 0, 2, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#else -DEF2(qemu_st8, 0, 3, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#endif -#if TARGET_LONG_BITS == 32 -DEF2(qemu_st16, 0, 2, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#else -DEF2(qemu_st16, 0, 3, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#endif -#if TARGET_LONG_BITS == 32 -DEF2(qemu_st32, 0, 2, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#else -DEF2(qemu_st32, 0, 3, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#endif -#if TARGET_LONG_BITS == 32 -DEF2(qemu_st64, 0, 3, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#else -DEF2(qemu_st64, 0, 4, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -#endif - -#else /* TCG_TARGET_REG_BITS == 32 */ - -DEF2(qemu_ld8u, 1, 1, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -DEF2(qemu_ld8s, 1, 1, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -DEF2(qemu_ld16u, 1, 1, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -DEF2(qemu_ld16s, 1, 1, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -DEF2(qemu_ld32u, 1, 1, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -DEF2(qemu_ld32s, 1, 1, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -DEF2(qemu_ld64, 1, 1, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) - -DEF2(qemu_st8, 0, 2, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -DEF2(qemu_st16, 0, 2, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -DEF2(qemu_st32, 0, 2, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) -DEF2(qemu_st64, 0, 2, 1, TCG_OPF_CALL_CLOBBER | TCG_OPF_SIDE_EFFECTS) - -#endif /* TCG_TARGET_REG_BITS != 32 */ - -#undef DEF2 diff --git a/qemu/qemu-git/tcg/.svn/text-base/tcg-runtime.h.svn-base b/qemu/qemu-git/tcg/.svn/text-base/tcg-runtime.h.svn-base deleted file mode 100644 index e750cc1..0000000 --- a/qemu/qemu-git/tcg/.svn/text-base/tcg-runtime.h.svn-base +++ /dev/null @@ -1,13 +0,0 @@ -#ifndef TCG_RUNTIME_H -#define TCG_RUNTIME_H - -/* tcg-runtime.c */ -int64_t tcg_helper_shl_i64(int64_t arg1, int64_t arg2); -int64_t tcg_helper_shr_i64(int64_t arg1, int64_t arg2); -int64_t tcg_helper_sar_i64(int64_t arg1, int64_t arg2); -int64_t tcg_helper_div_i64(int64_t arg1, int64_t arg2); -int64_t tcg_helper_rem_i64(int64_t arg1, int64_t arg2); -uint64_t tcg_helper_divu_i64(uint64_t arg1, uint64_t arg2); -uint64_t tcg_helper_remu_i64(uint64_t arg1, uint64_t arg2); - -#endif diff --git a/qemu/qemu-git/tcg/.svn/text-base/tcg.c.svn-base b/qemu/qemu-git/tcg/.svn/text-base/tcg.c.svn-base deleted file mode 100644 index 3c0e296..0000000 --- a/qemu/qemu-git/tcg/.svn/text-base/tcg.c.svn-base +++ /dev/null @@ -1,2085 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2008 Fabrice Bellard - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ - -/* define it to use liveness analysis (better code) */ -#define USE_LIVENESS_ANALYSIS - -#include "config.h" - -#ifndef CONFIG_DEBUG_TCG -/* define it to suppress various consistency checks (faster) */ -#define NDEBUG -#endif - -#include -#include -#include -#include -#include -#ifdef _WIN32 -#include -#endif -#ifdef _AIX -#include -#endif - -#include "qemu-common.h" -#include "cache-utils.h" -#include "host-utils.h" - -/* Note: the long term plan is to reduce the dependancies on the QEMU - CPU definitions. Currently they are used for qemu_ld/st - instructions */ -#define NO_CPU_IO_DEFS -#include "cpu.h" -#include "exec-all.h" - -#include "tcg-op.h" -#include "elf.h" - -#if defined(CONFIG_USE_GUEST_BASE) && !defined(TCG_TARGET_HAS_GUEST_BASE) -#error GUEST_BASE not supported on this host. -#endif - -static void patch_reloc(uint8_t *code_ptr, int type, - tcg_target_long value, tcg_target_long addend); - -static TCGOpDef tcg_op_defs[] = { -#define DEF(s, n, copy_size) { #s, 0, 0, n, n, 0, copy_size }, -#define DEF2(s, oargs, iargs, cargs, flags) { #s, oargs, iargs, cargs, iargs + oargs + cargs, flags, 0 }, -#include "tcg-opc.h" -#undef DEF -#undef DEF2 -}; - -static TCGRegSet tcg_target_available_regs[2]; -static TCGRegSet tcg_target_call_clobber_regs; - -/* XXX: move that inside the context */ -uint16_t *gen_opc_ptr; -TCGArg *gen_opparam_ptr; - -static inline void tcg_out8(TCGContext *s, uint8_t v) -{ - *s->code_ptr++ = v; -} - -static inline void tcg_out16(TCGContext *s, uint16_t v) -{ - *(uint16_t *)s->code_ptr = v; - s->code_ptr += 2; -} - -static inline void tcg_out32(TCGContext *s, uint32_t v) -{ - *(uint32_t *)s->code_ptr = v; - s->code_ptr += 4; -} - -/* label relocation processing */ - -void tcg_out_reloc(TCGContext *s, uint8_t *code_ptr, int type, - int label_index, long addend) -{ - TCGLabel *l; - TCGRelocation *r; - - l = &s->labels[label_index]; - if (l->has_value) { - /* FIXME: This may break relocations on RISC targets that - modify instruction fields in place. The caller may not have - written the initial value. */ - patch_reloc(code_ptr, type, l->u.value, addend); - } else { - /* add a new relocation entry */ - r = tcg_malloc(sizeof(TCGRelocation)); - r->type = type; - r->ptr = code_ptr; - r->addend = addend; - r->next = l->u.first_reloc; - l->u.first_reloc = r; - } -} - -static void tcg_out_label(TCGContext *s, int label_index, - tcg_target_long value) -{ - TCGLabel *l; - TCGRelocation *r; - - l = &s->labels[label_index]; - if (l->has_value) - tcg_abort(); - r = l->u.first_reloc; - while (r != NULL) { - patch_reloc(r->ptr, r->type, value, r->addend); - r = r->next; - } - l->has_value = 1; - l->u.value = value; -} - -int gen_new_label(void) -{ - TCGContext *s = &tcg_ctx; - int idx; - TCGLabel *l; - - if (s->nb_labels >= TCG_MAX_LABELS) - tcg_abort(); - idx = s->nb_labels++; - l = &s->labels[idx]; - l->has_value = 0; - l->u.first_reloc = NULL; - return idx; -} - -#include "tcg-target.c" - -/* pool based memory allocation */ -void *tcg_malloc_internal(TCGContext *s, int size) -{ - TCGPool *p; - int pool_size; - - if (size > TCG_POOL_CHUNK_SIZE) { - /* big malloc: insert a new pool (XXX: could optimize) */ - p = qemu_malloc(sizeof(TCGPool) + size); - p->size = size; - if (s->pool_current) - s->pool_current->next = p; - else - s->pool_first = p; - p->next = s->pool_current; - } else { - p = s->pool_current; - if (!p) { - p = s->pool_first; - if (!p) - goto new_pool; - } else { - if (!p->next) { - new_pool: - pool_size = TCG_POOL_CHUNK_SIZE; - p = qemu_malloc(sizeof(TCGPool) + pool_size); - p->size = pool_size; - p->next = NULL; - if (s->pool_current) - s->pool_current->next = p; - else - s->pool_first = p; - } else { - p = p->next; - } - } - } - s->pool_current = p; - s->pool_cur = p->data + size; - s->pool_end = p->data + p->size; - return p->data; -} - -void tcg_pool_reset(TCGContext *s) -{ - s->pool_cur = s->pool_end = NULL; - s->pool_current = NULL; -} - -void tcg_context_init(TCGContext *s) -{ - int op, total_args, n; - TCGOpDef *def; - TCGArgConstraint *args_ct; - int *sorted_args; - - memset(s, 0, sizeof(*s)); - s->temps = s->static_temps; - s->nb_globals = 0; - - /* Count total number of arguments and allocate the corresponding - space */ - total_args = 0; - for(op = 0; op < NB_OPS; op++) { - def = &tcg_op_defs[op]; - n = def->nb_iargs + def->nb_oargs; - total_args += n; - } - - args_ct = qemu_malloc(sizeof(TCGArgConstraint) * total_args); - sorted_args = qemu_malloc(sizeof(int) * total_args); - - for(op = 0; op < NB_OPS; op++) { - def = &tcg_op_defs[op]; - def->args_ct = args_ct; - def->sorted_args = sorted_args; - n = def->nb_iargs + def->nb_oargs; - sorted_args += n; - args_ct += n; - } - - tcg_target_init(s); - - /* init global prologue and epilogue */ - s->code_buf = code_gen_prologue; - s->code_ptr = s->code_buf; - tcg_target_qemu_prologue(s); - flush_icache_range((unsigned long)s->code_buf, - (unsigned long)s->code_ptr); -} - -void tcg_set_frame(TCGContext *s, int reg, - tcg_target_long start, tcg_target_long size) -{ - s->frame_start = start; - s->frame_end = start + size; - s->frame_reg = reg; -} - -void tcg_func_start(TCGContext *s) -{ - int i; - tcg_pool_reset(s); - s->nb_temps = s->nb_globals; - for(i = 0; i < (TCG_TYPE_COUNT * 2); i++) - s->first_free_temp[i] = -1; - s->labels = tcg_malloc(sizeof(TCGLabel) * TCG_MAX_LABELS); - s->nb_labels = 0; - s->current_frame_offset = s->frame_start; - - gen_opc_ptr = gen_opc_buf; - gen_opparam_ptr = gen_opparam_buf; -} - -static inline void tcg_temp_alloc(TCGContext *s, int n) -{ - if (n > TCG_MAX_TEMPS) - tcg_abort(); -} - -static inline int tcg_global_reg_new_internal(TCGType type, int reg, - const char *name) -{ - TCGContext *s = &tcg_ctx; - TCGTemp *ts; - int idx; - -#if TCG_TARGET_REG_BITS == 32 - if (type != TCG_TYPE_I32) - tcg_abort(); -#endif - if (tcg_regset_test_reg(s->reserved_regs, reg)) - tcg_abort(); - idx = s->nb_globals; - tcg_temp_alloc(s, s->nb_globals + 1); - ts = &s->temps[s->nb_globals]; - ts->base_type = type; - ts->type = type; - ts->fixed_reg = 1; - ts->reg = reg; - ts->name = name; - s->nb_globals++; - tcg_regset_set_reg(s->reserved_regs, reg); - return idx; -} - -TCGv_i32 tcg_global_reg_new_i32(int reg, const char *name) -{ - int idx; - - idx = tcg_global_reg_new_internal(TCG_TYPE_I32, reg, name); - return MAKE_TCGV_I32(idx); -} - -TCGv_i64 tcg_global_reg_new_i64(int reg, const char *name) -{ - int idx; - - idx = tcg_global_reg_new_internal(TCG_TYPE_I64, reg, name); - return MAKE_TCGV_I64(idx); -} - -static inline int tcg_global_mem_new_internal(TCGType type, int reg, - tcg_target_long offset, - const char *name) -{ - TCGContext *s = &tcg_ctx; - TCGTemp *ts; - int idx; - - idx = s->nb_globals; -#if TCG_TARGET_REG_BITS == 32 - if (type == TCG_TYPE_I64) { - char buf[64]; - tcg_temp_alloc(s, s->nb_globals + 2); - ts = &s->temps[s->nb_globals]; - ts->base_type = type; - ts->type = TCG_TYPE_I32; - ts->fixed_reg = 0; - ts->mem_allocated = 1; - ts->mem_reg = reg; -#ifdef TCG_TARGET_WORDS_BIGENDIAN - ts->mem_offset = offset + 4; -#else - ts->mem_offset = offset; -#endif - pstrcpy(buf, sizeof(buf), name); - pstrcat(buf, sizeof(buf), "_0"); - ts->name = strdup(buf); - ts++; - - ts->base_type = type; - ts->type = TCG_TYPE_I32; - ts->fixed_reg = 0; - ts->mem_allocated = 1; - ts->mem_reg = reg; -#ifdef TCG_TARGET_WORDS_BIGENDIAN - ts->mem_offset = offset; -#else - ts->mem_offset = offset + 4; -#endif - pstrcpy(buf, sizeof(buf), name); - pstrcat(buf, sizeof(buf), "_1"); - ts->name = strdup(buf); - - s->nb_globals += 2; - } else -#endif - { - tcg_temp_alloc(s, s->nb_globals + 1); - ts = &s->temps[s->nb_globals]; - ts->base_type = type; - ts->type = type; - ts->fixed_reg = 0; - ts->mem_allocated = 1; - ts->mem_reg = reg; - ts->mem_offset = offset; - ts->name = name; - s->nb_globals++; - } - return idx; -} - -TCGv_i32 tcg_global_mem_new_i32(int reg, tcg_target_long offset, - const char *name) -{ - int idx; - - idx = tcg_global_mem_new_internal(TCG_TYPE_I32, reg, offset, name); - return MAKE_TCGV_I32(idx); -} - -TCGv_i64 tcg_global_mem_new_i64(int reg, tcg_target_long offset, - const char *name) -{ - int idx; - - idx = tcg_global_mem_new_internal(TCG_TYPE_I64, reg, offset, name); - return MAKE_TCGV_I64(idx); -} - -static inline int tcg_temp_new_internal(TCGType type, int temp_local) -{ - TCGContext *s = &tcg_ctx; - TCGTemp *ts; - int idx, k; - - k = type; - if (temp_local) - k += TCG_TYPE_COUNT; - idx = s->first_free_temp[k]; - if (idx != -1) { - /* There is already an available temp with the - right type */ - ts = &s->temps[idx]; - s->first_free_temp[k] = ts->next_free_temp; - ts->temp_allocated = 1; - assert(ts->temp_local == temp_local); - } else { - idx = s->nb_temps; -#if TCG_TARGET_REG_BITS == 32 - if (type == TCG_TYPE_I64) { - tcg_temp_alloc(s, s->nb_temps + 2); - ts = &s->temps[s->nb_temps]; - ts->base_type = type; - ts->type = TCG_TYPE_I32; - ts->temp_allocated = 1; - ts->temp_local = temp_local; - ts->name = NULL; - ts++; - ts->base_type = TCG_TYPE_I32; - ts->type = TCG_TYPE_I32; - ts->temp_allocated = 1; - ts->temp_local = temp_local; - ts->name = NULL; - s->nb_temps += 2; - } else -#endif - { - tcg_temp_alloc(s, s->nb_temps + 1); - ts = &s->temps[s->nb_temps]; - ts->base_type = type; - ts->type = type; - ts->temp_allocated = 1; - ts->temp_local = temp_local; - ts->name = NULL; - s->nb_temps++; - } - } - return idx; -} - -TCGv_i32 tcg_temp_new_internal_i32(int temp_local) -{ - int idx; - - idx = tcg_temp_new_internal(TCG_TYPE_I32, temp_local); - return MAKE_TCGV_I32(idx); -} - -TCGv_i64 tcg_temp_new_internal_i64(int temp_local) -{ - int idx; - - idx = tcg_temp_new_internal(TCG_TYPE_I64, temp_local); - return MAKE_TCGV_I64(idx); -} - -static inline void tcg_temp_free_internal(int idx) -{ - TCGContext *s = &tcg_ctx; - TCGTemp *ts; - int k; - - assert(idx >= s->nb_globals && idx < s->nb_temps); - ts = &s->temps[idx]; - assert(ts->temp_allocated != 0); - ts->temp_allocated = 0; - k = ts->base_type; - if (ts->temp_local) - k += TCG_TYPE_COUNT; - ts->next_free_temp = s->first_free_temp[k]; - s->first_free_temp[k] = idx; -} - -void tcg_temp_free_i32(TCGv_i32 arg) -{ - tcg_temp_free_internal(GET_TCGV_I32(arg)); -} - -void tcg_temp_free_i64(TCGv_i64 arg) -{ - tcg_temp_free_internal(GET_TCGV_I64(arg)); -} - -TCGv_i32 tcg_const_i32(int32_t val) -{ - TCGv_i32 t0; - t0 = tcg_temp_new_i32(); - tcg_gen_movi_i32(t0, val); - return t0; -} - -TCGv_i64 tcg_const_i64(int64_t val) -{ - TCGv_i64 t0; - t0 = tcg_temp_new_i64(); - tcg_gen_movi_i64(t0, val); - return t0; -} - -TCGv_i32 tcg_const_local_i32(int32_t val) -{ - TCGv_i32 t0; - t0 = tcg_temp_local_new_i32(); - tcg_gen_movi_i32(t0, val); - return t0; -} - -TCGv_i64 tcg_const_local_i64(int64_t val) -{ - TCGv_i64 t0; - t0 = tcg_temp_local_new_i64(); - tcg_gen_movi_i64(t0, val); - return t0; -} - -void tcg_register_helper(void *func, const char *name) -{ - TCGContext *s = &tcg_ctx; - int n; - if ((s->nb_helpers + 1) > s->allocated_helpers) { - n = s->allocated_helpers; - if (n == 0) { - n = 4; - } else { - n *= 2; - } - s->helpers = realloc(s->helpers, n * sizeof(TCGHelperInfo)); - s->allocated_helpers = n; - } - s->helpers[s->nb_helpers].func = (tcg_target_ulong)func; - s->helpers[s->nb_helpers].name = name; - s->nb_helpers++; -} - -/* Note: we convert the 64 bit args to 32 bit and do some alignment - and endian swap. Maybe it would be better to do the alignment - and endian swap in tcg_reg_alloc_call(). */ -void tcg_gen_callN(TCGContext *s, TCGv_ptr func, unsigned int flags, - int sizemask, TCGArg ret, int nargs, TCGArg *args) -{ - int call_type; - int i; - int real_args; - int nb_rets; - TCGArg *nparam; - *gen_opc_ptr++ = INDEX_op_call; - nparam = gen_opparam_ptr++; - call_type = (flags & TCG_CALL_TYPE_MASK); - if (ret != TCG_CALL_DUMMY_ARG) { -#if TCG_TARGET_REG_BITS < 64 - if (sizemask & 1) { -#ifdef TCG_TARGET_WORDS_BIGENDIAN - *gen_opparam_ptr++ = ret + 1; - *gen_opparam_ptr++ = ret; -#else - *gen_opparam_ptr++ = ret; - *gen_opparam_ptr++ = ret + 1; -#endif - nb_rets = 2; - } else -#endif - { - *gen_opparam_ptr++ = ret; - nb_rets = 1; - } - } else { - nb_rets = 0; - } - real_args = 0; - for (i = 0; i < nargs; i++) { -#if TCG_TARGET_REG_BITS < 64 - if (sizemask & (2 << i)) { -#ifdef TCG_TARGET_I386 - /* REGPARM case: if the third parameter is 64 bit, it is - allocated on the stack */ - if (i == 2 && call_type == TCG_CALL_TYPE_REGPARM) { - call_type = TCG_CALL_TYPE_REGPARM_2; - flags = (flags & ~TCG_CALL_TYPE_MASK) | call_type; - } -#endif -#ifdef TCG_TARGET_CALL_ALIGN_ARGS - /* some targets want aligned 64 bit args */ - if (real_args & 1) { - *gen_opparam_ptr++ = TCG_CALL_DUMMY_ARG; - real_args++; - } -#endif -#ifdef TCG_TARGET_WORDS_BIGENDIAN - *gen_opparam_ptr++ = args[i] + 1; - *gen_opparam_ptr++ = args[i]; -#else - *gen_opparam_ptr++ = args[i]; - *gen_opparam_ptr++ = args[i] + 1; -#endif - real_args += 2; - } else -#endif - { - *gen_opparam_ptr++ = args[i]; - real_args++; - } - } - *gen_opparam_ptr++ = GET_TCGV_PTR(func); - - *gen_opparam_ptr++ = flags; - - *nparam = (nb_rets << 16) | (real_args + 1); - - /* total parameters, needed to go backward in the instruction stream */ - *gen_opparam_ptr++ = 1 + nb_rets + real_args + 3; -} - -#if TCG_TARGET_REG_BITS == 32 -void tcg_gen_shifti_i64(TCGv_i64 ret, TCGv_i64 arg1, - int c, int right, int arith) -{ - if (c == 0) { - tcg_gen_mov_i32(TCGV_LOW(ret), TCGV_LOW(arg1)); - tcg_gen_mov_i32(TCGV_HIGH(ret), TCGV_HIGH(arg1)); - } else if (c >= 32) { - c -= 32; - if (right) { - if (arith) { - tcg_gen_sari_i32(TCGV_LOW(ret), TCGV_HIGH(arg1), c); - tcg_gen_sari_i32(TCGV_HIGH(ret), TCGV_HIGH(arg1), 31); - } else { - tcg_gen_shri_i32(TCGV_LOW(ret), TCGV_HIGH(arg1), c); - tcg_gen_movi_i32(TCGV_HIGH(ret), 0); - } - } else { - tcg_gen_shli_i32(TCGV_HIGH(ret), TCGV_LOW(arg1), c); - tcg_gen_movi_i32(TCGV_LOW(ret), 0); - } - } else { - TCGv_i32 t0, t1; - - t0 = tcg_temp_new_i32(); - t1 = tcg_temp_new_i32(); - if (right) { - tcg_gen_shli_i32(t0, TCGV_HIGH(arg1), 32 - c); - if (arith) - tcg_gen_sari_i32(t1, TCGV_HIGH(arg1), c); - else - tcg_gen_shri_i32(t1, TCGV_HIGH(arg1), c); - tcg_gen_shri_i32(TCGV_LOW(ret), TCGV_LOW(arg1), c); - tcg_gen_or_i32(TCGV_LOW(ret), TCGV_LOW(ret), t0); - tcg_gen_mov_i32(TCGV_HIGH(ret), t1); - } else { - tcg_gen_shri_i32(t0, TCGV_LOW(arg1), 32 - c); - /* Note: ret can be the same as arg1, so we use t1 */ - tcg_gen_shli_i32(t1, TCGV_LOW(arg1), c); - tcg_gen_shli_i32(TCGV_HIGH(ret), TCGV_HIGH(arg1), c); - tcg_gen_or_i32(TCGV_HIGH(ret), TCGV_HIGH(ret), t0); - tcg_gen_mov_i32(TCGV_LOW(ret), t1); - } - tcg_temp_free_i32(t0); - tcg_temp_free_i32(t1); - } -} -#endif - -static void tcg_reg_alloc_start(TCGContext *s) -{ - int i; - TCGTemp *ts; - for(i = 0; i < s->nb_globals; i++) { - ts = &s->temps[i]; - if (ts->fixed_reg) { - ts->val_type = TEMP_VAL_REG; - } else { - ts->val_type = TEMP_VAL_MEM; - } - } - for(i = s->nb_globals; i < s->nb_temps; i++) { - ts = &s->temps[i]; - ts->val_type = TEMP_VAL_DEAD; - ts->mem_allocated = 0; - ts->fixed_reg = 0; - } - for(i = 0; i < TCG_TARGET_NB_REGS; i++) { - s->reg_to_temp[i] = -1; - } -} - -static char *tcg_get_arg_str_idx(TCGContext *s, char *buf, int buf_size, - int idx) -{ - TCGTemp *ts; - - ts = &s->temps[idx]; - if (idx < s->nb_globals) { - pstrcpy(buf, buf_size, ts->name); - } else { - if (ts->temp_local) - snprintf(buf, buf_size, "loc%d", idx - s->nb_globals); - else - snprintf(buf, buf_size, "tmp%d", idx - s->nb_globals); - } - return buf; -} - -char *tcg_get_arg_str_i32(TCGContext *s, char *buf, int buf_size, TCGv_i32 arg) -{ - return tcg_get_arg_str_idx(s, buf, buf_size, GET_TCGV_I32(arg)); -} - -char *tcg_get_arg_str_i64(TCGContext *s, char *buf, int buf_size, TCGv_i64 arg) -{ - return tcg_get_arg_str_idx(s, buf, buf_size, GET_TCGV_I64(arg)); -} - -static int helper_cmp(const void *p1, const void *p2) -{ - const TCGHelperInfo *th1 = p1; - const TCGHelperInfo *th2 = p2; - if (th1->func < th2->func) - return -1; - else if (th1->func == th2->func) - return 0; - else - return 1; -} - -/* find helper definition (Note: A hash table would be better) */ -static TCGHelperInfo *tcg_find_helper(TCGContext *s, tcg_target_ulong val) -{ - int m, m_min, m_max; - TCGHelperInfo *th; - tcg_target_ulong v; - - if (unlikely(!s->helpers_sorted)) { - qsort(s->helpers, s->nb_helpers, sizeof(TCGHelperInfo), - helper_cmp); - s->helpers_sorted = 1; - } - - /* binary search */ - m_min = 0; - m_max = s->nb_helpers - 1; - while (m_min <= m_max) { - m = (m_min + m_max) >> 1; - th = &s->helpers[m]; - v = th->func; - if (v == val) - return th; - else if (val < v) { - m_max = m - 1; - } else { - m_min = m + 1; - } - } - return NULL; -} - -static const char * const cond_name[] = -{ - [TCG_COND_EQ] = "eq", - [TCG_COND_NE] = "ne", - [TCG_COND_LT] = "lt", - [TCG_COND_GE] = "ge", - [TCG_COND_LE] = "le", - [TCG_COND_GT] = "gt", - [TCG_COND_LTU] = "ltu", - [TCG_COND_GEU] = "geu", - [TCG_COND_LEU] = "leu", - [TCG_COND_GTU] = "gtu" -}; - -void tcg_dump_ops(TCGContext *s, FILE *outfile) -{ - const uint16_t *opc_ptr; - const TCGArg *args; - TCGArg arg; - int c, i, k, nb_oargs, nb_iargs, nb_cargs, first_insn; - const TCGOpDef *def; - char buf[128]; - - first_insn = 1; - opc_ptr = gen_opc_buf; - args = gen_opparam_buf; - while (opc_ptr < gen_opc_ptr) { - c = *opc_ptr++; - def = &tcg_op_defs[c]; - if (c == INDEX_op_debug_insn_start) { - uint64_t pc; -#if TARGET_LONG_BITS > TCG_TARGET_REG_BITS - pc = ((uint64_t)args[1] << 32) | args[0]; -#else - pc = args[0]; -#endif - if (!first_insn) - fprintf(outfile, "\n"); - fprintf(outfile, " ---- 0x%" PRIx64, pc); - first_insn = 0; - nb_oargs = def->nb_oargs; - nb_iargs = def->nb_iargs; - nb_cargs = def->nb_cargs; - } else if (c == INDEX_op_call) { - TCGArg arg; - - /* variable number of arguments */ - arg = *args++; - nb_oargs = arg >> 16; - nb_iargs = arg & 0xffff; - nb_cargs = def->nb_cargs; - - fprintf(outfile, " %s ", def->name); - - /* function name */ - fprintf(outfile, "%s", - tcg_get_arg_str_idx(s, buf, sizeof(buf), args[nb_oargs + nb_iargs - 1])); - /* flags */ - fprintf(outfile, ",$0x%" TCG_PRIlx, - args[nb_oargs + nb_iargs]); - /* nb out args */ - fprintf(outfile, ",$%d", nb_oargs); - for(i = 0; i < nb_oargs; i++) { - fprintf(outfile, ","); - fprintf(outfile, "%s", - tcg_get_arg_str_idx(s, buf, sizeof(buf), args[i])); - } - for(i = 0; i < (nb_iargs - 1); i++) { - fprintf(outfile, ","); - if (args[nb_oargs + i] == TCG_CALL_DUMMY_ARG) { - fprintf(outfile, ""); - } else { - fprintf(outfile, "%s", - tcg_get_arg_str_idx(s, buf, sizeof(buf), args[nb_oargs + i])); - } - } - } else if (c == INDEX_op_movi_i32 -#if TCG_TARGET_REG_BITS == 64 - || c == INDEX_op_movi_i64 -#endif - ) { - tcg_target_ulong val; - TCGHelperInfo *th; - - nb_oargs = def->nb_oargs; - nb_iargs = def->nb_iargs; - nb_cargs = def->nb_cargs; - fprintf(outfile, " %s %s,$", def->name, - tcg_get_arg_str_idx(s, buf, sizeof(buf), args[0])); - val = args[1]; - th = tcg_find_helper(s, val); - if (th) { - fprintf(outfile, "%s", th->name); - } else { - if (c == INDEX_op_movi_i32) - fprintf(outfile, "0x%x", (uint32_t)val); - else - fprintf(outfile, "0x%" PRIx64 , (uint64_t)val); - } - } else { - fprintf(outfile, " %s ", def->name); - if (c == INDEX_op_nopn) { - /* variable number of arguments */ - nb_cargs = *args; - nb_oargs = 0; - nb_iargs = 0; - } else { - nb_oargs = def->nb_oargs; - nb_iargs = def->nb_iargs; - nb_cargs = def->nb_cargs; - } - - k = 0; - for(i = 0; i < nb_oargs; i++) { - if (k != 0) - fprintf(outfile, ","); - fprintf(outfile, "%s", - tcg_get_arg_str_idx(s, buf, sizeof(buf), args[k++])); - } - for(i = 0; i < nb_iargs; i++) { - if (k != 0) - fprintf(outfile, ","); - fprintf(outfile, "%s", - tcg_get_arg_str_idx(s, buf, sizeof(buf), args[k++])); - } - if (c == INDEX_op_brcond_i32 -#if TCG_TARGET_REG_BITS == 32 - || c == INDEX_op_brcond2_i32 -#elif TCG_TARGET_REG_BITS == 64 - || c == INDEX_op_brcond_i64 -#endif - ) { - if (args[k] < ARRAY_SIZE(cond_name) && cond_name[args[k]]) - fprintf(outfile, ",%s", cond_name[args[k++]]); - else - fprintf(outfile, ",$0x%" TCG_PRIlx, args[k++]); - i = 1; - } - else - i = 0; - for(; i < nb_cargs; i++) { - if (k != 0) - fprintf(outfile, ","); - arg = args[k++]; - fprintf(outfile, "$0x%" TCG_PRIlx, arg); - } - } - fprintf(outfile, "\n"); - args += nb_iargs + nb_oargs + nb_cargs; - } -} - -/* we give more priority to constraints with less registers */ -static int get_constraint_priority(const TCGOpDef *def, int k) -{ - const TCGArgConstraint *arg_ct; - - int i, n; - arg_ct = &def->args_ct[k]; - if (arg_ct->ct & TCG_CT_ALIAS) { - /* an alias is equivalent to a single register */ - n = 1; - } else { - if (!(arg_ct->ct & TCG_CT_REG)) - return 0; - n = 0; - for(i = 0; i < TCG_TARGET_NB_REGS; i++) { - if (tcg_regset_test_reg(arg_ct->u.regs, i)) - n++; - } - } - return TCG_TARGET_NB_REGS - n + 1; -} - -/* sort from highest priority to lowest */ -static void sort_constraints(TCGOpDef *def, int start, int n) -{ - int i, j, p1, p2, tmp; - - for(i = 0; i < n; i++) - def->sorted_args[start + i] = start + i; - if (n <= 1) - return; - for(i = 0; i < n - 1; i++) { - for(j = i + 1; j < n; j++) { - p1 = get_constraint_priority(def, def->sorted_args[start + i]); - p2 = get_constraint_priority(def, def->sorted_args[start + j]); - if (p1 < p2) { - tmp = def->sorted_args[start + i]; - def->sorted_args[start + i] = def->sorted_args[start + j]; - def->sorted_args[start + j] = tmp; - } - } - } -} - -void tcg_add_target_add_op_defs(const TCGTargetOpDef *tdefs) -{ - int op; - TCGOpDef *def; - const char *ct_str; - int i, nb_args; - - for(;;) { - if (tdefs->op < 0) - break; - op = tdefs->op; - assert(op >= 0 && op < NB_OPS); - def = &tcg_op_defs[op]; - nb_args = def->nb_iargs + def->nb_oargs; - for(i = 0; i < nb_args; i++) { - ct_str = tdefs->args_ct_str[i]; - tcg_regset_clear(def->args_ct[i].u.regs); - def->args_ct[i].ct = 0; - if (ct_str[0] >= '0' && ct_str[0] <= '9') { - int oarg; - oarg = ct_str[0] - '0'; - assert(oarg < def->nb_oargs); - assert(def->args_ct[oarg].ct & TCG_CT_REG); - /* TCG_CT_ALIAS is for the output arguments. The input - argument is tagged with TCG_CT_IALIAS. */ - def->args_ct[i] = def->args_ct[oarg]; - def->args_ct[oarg].ct = TCG_CT_ALIAS; - def->args_ct[oarg].alias_index = i; - def->args_ct[i].ct |= TCG_CT_IALIAS; - def->args_ct[i].alias_index = oarg; - } else { - for(;;) { - if (*ct_str == '\0') - break; - switch(*ct_str) { - case 'i': - def->args_ct[i].ct |= TCG_CT_CONST; - ct_str++; - break; - default: - if (target_parse_constraint(&def->args_ct[i], &ct_str) < 0) { - fprintf(stderr, "Invalid constraint '%s' for arg %d of operation '%s'\n", - ct_str, i, def->name); - exit(1); - } - } - } - } - } - - /* sort the constraints (XXX: this is just an heuristic) */ - sort_constraints(def, 0, def->nb_oargs); - sort_constraints(def, def->nb_oargs, def->nb_iargs); - -#if 0 - { - int i; - - printf("%s: sorted=", def->name); - for(i = 0; i < def->nb_oargs + def->nb_iargs; i++) - printf(" %d", def->sorted_args[i]); - printf("\n"); - } -#endif - tdefs++; - } - -} - -#ifdef USE_LIVENESS_ANALYSIS - -/* set a nop for an operation using 'nb_args' */ -static inline void tcg_set_nop(TCGContext *s, uint16_t *opc_ptr, - TCGArg *args, int nb_args) -{ - if (nb_args == 0) { - *opc_ptr = INDEX_op_nop; - } else { - *opc_ptr = INDEX_op_nopn; - args[0] = nb_args; - args[nb_args - 1] = nb_args; - } -} - -/* liveness analysis: end of function: globals are live, temps are - dead. */ -/* XXX: at this stage, not used as there would be little gains because - most TBs end with a conditional jump. */ -static inline void tcg_la_func_end(TCGContext *s, uint8_t *dead_temps) -{ - memset(dead_temps, 0, s->nb_globals); - memset(dead_temps + s->nb_globals, 1, s->nb_temps - s->nb_globals); -} - -/* liveness analysis: end of basic block: globals are live, temps are - dead, local temps are live. */ -static inline void tcg_la_bb_end(TCGContext *s, uint8_t *dead_temps) -{ - int i; - TCGTemp *ts; - - memset(dead_temps, 0, s->nb_globals); - ts = &s->temps[s->nb_globals]; - for(i = s->nb_globals; i < s->nb_temps; i++) { - if (ts->temp_local) - dead_temps[i] = 0; - else - dead_temps[i] = 1; - ts++; - } -} - -/* Liveness analysis : update the opc_dead_iargs array to tell if a - given input arguments is dead. Instructions updating dead - temporaries are removed. */ -static void tcg_liveness_analysis(TCGContext *s) -{ - int i, op_index, op, nb_args, nb_iargs, nb_oargs, arg, nb_ops; - TCGArg *args; - const TCGOpDef *def; - uint8_t *dead_temps; - unsigned int dead_iargs; - - gen_opc_ptr++; /* skip end */ - - nb_ops = gen_opc_ptr - gen_opc_buf; - - s->op_dead_iargs = tcg_malloc(nb_ops * sizeof(uint16_t)); - - dead_temps = tcg_malloc(s->nb_temps); - memset(dead_temps, 1, s->nb_temps); - - args = gen_opparam_ptr; - op_index = nb_ops - 1; - while (op_index >= 0) { - op = gen_opc_buf[op_index]; - def = &tcg_op_defs[op]; - switch(op) { - case INDEX_op_call: - { - int call_flags; - - nb_args = args[-1]; - args -= nb_args; - nb_iargs = args[0] & 0xffff; - nb_oargs = args[0] >> 16; - args++; - call_flags = args[nb_oargs + nb_iargs]; - - /* pure functions can be removed if their result is not - used */ - if (call_flags & TCG_CALL_PURE) { - for(i = 0; i < nb_oargs; i++) { - arg = args[i]; - if (!dead_temps[arg]) - goto do_not_remove_call; - } - tcg_set_nop(s, gen_opc_buf + op_index, - args - 1, nb_args); - } else { - do_not_remove_call: - - /* output args are dead */ - for(i = 0; i < nb_oargs; i++) { - arg = args[i]; - dead_temps[arg] = 1; - } - - if (!(call_flags & TCG_CALL_CONST)) { - /* globals are live (they may be used by the call) */ - memset(dead_temps, 0, s->nb_globals); - } - - /* input args are live */ - dead_iargs = 0; - for(i = 0; i < nb_iargs; i++) { - arg = args[i + nb_oargs]; - if (arg != TCG_CALL_DUMMY_ARG) { - if (dead_temps[arg]) { - dead_iargs |= (1 << i); - } - dead_temps[arg] = 0; - } - } - s->op_dead_iargs[op_index] = dead_iargs; - } - args--; - } - break; - case INDEX_op_set_label: - args--; - /* mark end of basic block */ - tcg_la_bb_end(s, dead_temps); - break; - case INDEX_op_debug_insn_start: - args -= def->nb_args; - break; - case INDEX_op_nopn: - nb_args = args[-1]; - args -= nb_args; - break; - case INDEX_op_discard: - args--; - /* mark the temporary as dead */ - dead_temps[args[0]] = 1; - break; - case INDEX_op_end: - break; - /* XXX: optimize by hardcoding common cases (e.g. triadic ops) */ - default: - args -= def->nb_args; - nb_iargs = def->nb_iargs; - nb_oargs = def->nb_oargs; - - /* Test if the operation can be removed because all - its outputs are dead. We assume that nb_oargs == 0 - implies side effects */ - if (!(def->flags & TCG_OPF_SIDE_EFFECTS) && nb_oargs != 0) { - for(i = 0; i < nb_oargs; i++) { - arg = args[i]; - if (!dead_temps[arg]) - goto do_not_remove; - } - tcg_set_nop(s, gen_opc_buf + op_index, args, def->nb_args); -#ifdef CONFIG_PROFILER - s->del_op_count++; -#endif - } else { - do_not_remove: - - /* output args are dead */ - for(i = 0; i < nb_oargs; i++) { - arg = args[i]; - dead_temps[arg] = 1; - } - - /* if end of basic block, update */ - if (def->flags & TCG_OPF_BB_END) { - tcg_la_bb_end(s, dead_temps); - } else if (def->flags & TCG_OPF_CALL_CLOBBER) { - /* globals are live */ - memset(dead_temps, 0, s->nb_globals); - } - - /* input args are live */ - dead_iargs = 0; - for(i = 0; i < nb_iargs; i++) { - arg = args[i + nb_oargs]; - if (dead_temps[arg]) { - dead_iargs |= (1 << i); - } - dead_temps[arg] = 0; - } - s->op_dead_iargs[op_index] = dead_iargs; - } - break; - } - op_index--; - } - - if (args != gen_opparam_buf) - tcg_abort(); -} -#else -/* dummy liveness analysis */ -void tcg_liveness_analysis(TCGContext *s) -{ - int nb_ops; - nb_ops = gen_opc_ptr - gen_opc_buf; - - s->op_dead_iargs = tcg_malloc(nb_ops * sizeof(uint16_t)); - memset(s->op_dead_iargs, 0, nb_ops * sizeof(uint16_t)); -} -#endif - -#ifndef NDEBUG -static void dump_regs(TCGContext *s) -{ - TCGTemp *ts; - int i; - char buf[64]; - - for(i = 0; i < s->nb_temps; i++) { - ts = &s->temps[i]; - printf(" %10s: ", tcg_get_arg_str_idx(s, buf, sizeof(buf), i)); - switch(ts->val_type) { - case TEMP_VAL_REG: - printf("%s", tcg_target_reg_names[ts->reg]); - break; - case TEMP_VAL_MEM: - printf("%d(%s)", (int)ts->mem_offset, tcg_target_reg_names[ts->mem_reg]); - break; - case TEMP_VAL_CONST: - printf("$0x%" TCG_PRIlx, ts->val); - break; - case TEMP_VAL_DEAD: - printf("D"); - break; - default: - printf("???"); - break; - } - printf("\n"); - } - - for(i = 0; i < TCG_TARGET_NB_REGS; i++) { - if (s->reg_to_temp[i] >= 0) { - printf("%s: %s\n", - tcg_target_reg_names[i], - tcg_get_arg_str_idx(s, buf, sizeof(buf), s->reg_to_temp[i])); - } - } -} - -static void check_regs(TCGContext *s) -{ - int reg, k; - TCGTemp *ts; - char buf[64]; - - for(reg = 0; reg < TCG_TARGET_NB_REGS; reg++) { - k = s->reg_to_temp[reg]; - if (k >= 0) { - ts = &s->temps[k]; - if (ts->val_type != TEMP_VAL_REG || - ts->reg != reg) { - printf("Inconsistency for register %s:\n", - tcg_target_reg_names[reg]); - goto fail; - } - } - } - for(k = 0; k < s->nb_temps; k++) { - ts = &s->temps[k]; - if (ts->val_type == TEMP_VAL_REG && - !ts->fixed_reg && - s->reg_to_temp[ts->reg] != k) { - printf("Inconsistency for temp %s:\n", - tcg_get_arg_str_idx(s, buf, sizeof(buf), k)); - fail: - printf("reg state:\n"); - dump_regs(s); - tcg_abort(); - } - } -} -#endif - -static void temp_allocate_frame(TCGContext *s, int temp) -{ - TCGTemp *ts; - ts = &s->temps[temp]; - s->current_frame_offset = (s->current_frame_offset + sizeof(tcg_target_long) - 1) & ~(sizeof(tcg_target_long) - 1); - if (s->current_frame_offset + sizeof(tcg_target_long) > s->frame_end) - tcg_abort(); - ts->mem_offset = s->current_frame_offset; - ts->mem_reg = s->frame_reg; - ts->mem_allocated = 1; - s->current_frame_offset += sizeof(tcg_target_long); -} - -/* free register 'reg' by spilling the corresponding temporary if necessary */ -static void tcg_reg_free(TCGContext *s, int reg) -{ - TCGTemp *ts; - int temp; - - temp = s->reg_to_temp[reg]; - if (temp != -1) { - ts = &s->temps[temp]; - assert(ts->val_type == TEMP_VAL_REG); - if (!ts->mem_coherent) { - if (!ts->mem_allocated) - temp_allocate_frame(s, temp); - tcg_out_st(s, ts->type, reg, ts->mem_reg, ts->mem_offset); - } - ts->val_type = TEMP_VAL_MEM; - s->reg_to_temp[reg] = -1; - } -} - -/* Allocate a register belonging to reg1 & ~reg2 */ -static int tcg_reg_alloc(TCGContext *s, TCGRegSet reg1, TCGRegSet reg2) -{ - int i, reg; - TCGRegSet reg_ct; - - tcg_regset_andnot(reg_ct, reg1, reg2); - - /* first try free registers */ - for(i = 0; i < ARRAY_SIZE(tcg_target_reg_alloc_order); i++) { - reg = tcg_target_reg_alloc_order[i]; - if (tcg_regset_test_reg(reg_ct, reg) && s->reg_to_temp[reg] == -1) - return reg; - } - - /* XXX: do better spill choice */ - for(i = 0; i < ARRAY_SIZE(tcg_target_reg_alloc_order); i++) { - reg = tcg_target_reg_alloc_order[i]; - if (tcg_regset_test_reg(reg_ct, reg)) { - tcg_reg_free(s, reg); - return reg; - } - } - - tcg_abort(); -} - -/* save a temporary to memory. 'allocated_regs' is used in case a - temporary registers needs to be allocated to store a constant. */ -static void temp_save(TCGContext *s, int temp, TCGRegSet allocated_regs) -{ - TCGTemp *ts; - int reg; - - ts = &s->temps[temp]; - if (!ts->fixed_reg) { - switch(ts->val_type) { - case TEMP_VAL_REG: - tcg_reg_free(s, ts->reg); - break; - case TEMP_VAL_DEAD: - ts->val_type = TEMP_VAL_MEM; - break; - case TEMP_VAL_CONST: - reg = tcg_reg_alloc(s, tcg_target_available_regs[ts->type], - allocated_regs); - if (!ts->mem_allocated) - temp_allocate_frame(s, temp); - tcg_out_movi(s, ts->type, reg, ts->val); - tcg_out_st(s, ts->type, reg, ts->mem_reg, ts->mem_offset); - ts->val_type = TEMP_VAL_MEM; - break; - case TEMP_VAL_MEM: - break; - default: - tcg_abort(); - } - } -} - -/* save globals to their cannonical location and assume they can be - modified be the following code. 'allocated_regs' is used in case a - temporary registers needs to be allocated to store a constant. */ -static void save_globals(TCGContext *s, TCGRegSet allocated_regs) -{ - int i; - - for(i = 0; i < s->nb_globals; i++) { - temp_save(s, i, allocated_regs); - } -} - -/* at the end of a basic block, we assume all temporaries are dead and - all globals are stored at their canonical location. */ -static void tcg_reg_alloc_bb_end(TCGContext *s, TCGRegSet allocated_regs) -{ - TCGTemp *ts; - int i; - - for(i = s->nb_globals; i < s->nb_temps; i++) { - ts = &s->temps[i]; - if (ts->temp_local) { - temp_save(s, i, allocated_regs); - } else { - if (ts->val_type == TEMP_VAL_REG) { - s->reg_to_temp[ts->reg] = -1; - } - ts->val_type = TEMP_VAL_DEAD; - } - } - - save_globals(s, allocated_regs); -} - -#define IS_DEAD_IARG(n) ((dead_iargs >> (n)) & 1) - -static void tcg_reg_alloc_movi(TCGContext *s, const TCGArg *args) -{ - TCGTemp *ots; - tcg_target_ulong val; - - ots = &s->temps[args[0]]; - val = args[1]; - - if (ots->fixed_reg) { - /* for fixed registers, we do not do any constant - propagation */ - tcg_out_movi(s, ots->type, ots->reg, val); - } else { - /* The movi is not explicitly generated here */ - if (ots->val_type == TEMP_VAL_REG) - s->reg_to_temp[ots->reg] = -1; - ots->val_type = TEMP_VAL_CONST; - ots->val = val; - } -} - -static void tcg_reg_alloc_mov(TCGContext *s, const TCGOpDef *def, - const TCGArg *args, - unsigned int dead_iargs) -{ - TCGTemp *ts, *ots; - int reg; - const TCGArgConstraint *arg_ct; - - ots = &s->temps[args[0]]; - ts = &s->temps[args[1]]; - arg_ct = &def->args_ct[0]; - - /* XXX: always mark arg dead if IS_DEAD_IARG(0) */ - if (ts->val_type == TEMP_VAL_REG) { - if (IS_DEAD_IARG(0) && !ts->fixed_reg && !ots->fixed_reg) { - /* the mov can be suppressed */ - if (ots->val_type == TEMP_VAL_REG) - s->reg_to_temp[ots->reg] = -1; - reg = ts->reg; - s->reg_to_temp[reg] = -1; - ts->val_type = TEMP_VAL_DEAD; - } else { - if (ots->val_type == TEMP_VAL_REG) { - reg = ots->reg; - } else { - reg = tcg_reg_alloc(s, arg_ct->u.regs, s->reserved_regs); - } - if (ts->reg != reg) { - tcg_out_mov(s, reg, ts->reg); - } - } - } else if (ts->val_type == TEMP_VAL_MEM) { - if (ots->val_type == TEMP_VAL_REG) { - reg = ots->reg; - } else { - reg = tcg_reg_alloc(s, arg_ct->u.regs, s->reserved_regs); - } - tcg_out_ld(s, ts->type, reg, ts->mem_reg, ts->mem_offset); - } else if (ts->val_type == TEMP_VAL_CONST) { - if (ots->fixed_reg) { - reg = ots->reg; - tcg_out_movi(s, ots->type, reg, ts->val); - } else { - /* propagate constant */ - if (ots->val_type == TEMP_VAL_REG) - s->reg_to_temp[ots->reg] = -1; - ots->val_type = TEMP_VAL_CONST; - ots->val = ts->val; - return; - } - } else { - tcg_abort(); - } - s->reg_to_temp[reg] = args[0]; - ots->reg = reg; - ots->val_type = TEMP_VAL_REG; - ots->mem_coherent = 0; -} - -static void tcg_reg_alloc_op(TCGContext *s, - const TCGOpDef *def, int opc, - const TCGArg *args, - unsigned int dead_iargs) -{ - TCGRegSet allocated_regs; - int i, k, nb_iargs, nb_oargs, reg; - TCGArg arg; - const TCGArgConstraint *arg_ct; - TCGTemp *ts; - TCGArg new_args[TCG_MAX_OP_ARGS]; - int const_args[TCG_MAX_OP_ARGS]; - - nb_oargs = def->nb_oargs; - nb_iargs = def->nb_iargs; - - /* copy constants */ - memcpy(new_args + nb_oargs + nb_iargs, - args + nb_oargs + nb_iargs, - sizeof(TCGArg) * def->nb_cargs); - - /* satisfy input constraints */ - tcg_regset_set(allocated_regs, s->reserved_regs); - for(k = 0; k < nb_iargs; k++) { - i = def->sorted_args[nb_oargs + k]; - arg = args[i]; - arg_ct = &def->args_ct[i]; - ts = &s->temps[arg]; - if (ts->val_type == TEMP_VAL_MEM) { - reg = tcg_reg_alloc(s, arg_ct->u.regs, allocated_regs); - tcg_out_ld(s, ts->type, reg, ts->mem_reg, ts->mem_offset); - ts->val_type = TEMP_VAL_REG; - ts->reg = reg; - ts->mem_coherent = 1; - s->reg_to_temp[reg] = arg; - } else if (ts->val_type == TEMP_VAL_CONST) { - if (tcg_target_const_match(ts->val, arg_ct)) { - /* constant is OK for instruction */ - const_args[i] = 1; - new_args[i] = ts->val; - goto iarg_end; - } else { - /* need to move to a register */ - reg = tcg_reg_alloc(s, arg_ct->u.regs, allocated_regs); - tcg_out_movi(s, ts->type, reg, ts->val); - ts->val_type = TEMP_VAL_REG; - ts->reg = reg; - ts->mem_coherent = 0; - s->reg_to_temp[reg] = arg; - } - } - assert(ts->val_type == TEMP_VAL_REG); - if (arg_ct->ct & TCG_CT_IALIAS) { - if (ts->fixed_reg) { - /* if fixed register, we must allocate a new register - if the alias is not the same register */ - if (arg != args[arg_ct->alias_index]) - goto allocate_in_reg; - } else { - /* if the input is aliased to an output and if it is - not dead after the instruction, we must allocate - a new register and move it */ - if (!IS_DEAD_IARG(i - nb_oargs)) - goto allocate_in_reg; - } - } - reg = ts->reg; - if (tcg_regset_test_reg(arg_ct->u.regs, reg)) { - /* nothing to do : the constraint is satisfied */ - } else { - allocate_in_reg: - /* allocate a new register matching the constraint - and move the temporary register into it */ - reg = tcg_reg_alloc(s, arg_ct->u.regs, allocated_regs); - tcg_out_mov(s, reg, ts->reg); - } - new_args[i] = reg; - const_args[i] = 0; - tcg_regset_set_reg(allocated_regs, reg); - iarg_end: ; - } - - if (def->flags & TCG_OPF_BB_END) { - tcg_reg_alloc_bb_end(s, allocated_regs); - } else { - /* mark dead temporaries and free the associated registers */ - for(i = 0; i < nb_iargs; i++) { - arg = args[nb_oargs + i]; - if (IS_DEAD_IARG(i)) { - ts = &s->temps[arg]; - if (!ts->fixed_reg) { - if (ts->val_type == TEMP_VAL_REG) - s->reg_to_temp[ts->reg] = -1; - ts->val_type = TEMP_VAL_DEAD; - } - } - } - - if (def->flags & TCG_OPF_CALL_CLOBBER) { - /* XXX: permit generic clobber register list ? */ - for(reg = 0; reg < TCG_TARGET_NB_REGS; reg++) { - if (tcg_regset_test_reg(tcg_target_call_clobber_regs, reg)) { - tcg_reg_free(s, reg); - } - } - /* XXX: for load/store we could do that only for the slow path - (i.e. when a memory callback is called) */ - - /* store globals and free associated registers (we assume the insn - can modify any global. */ - save_globals(s, allocated_regs); - } - - /* satisfy the output constraints */ - tcg_regset_set(allocated_regs, s->reserved_regs); - for(k = 0; k < nb_oargs; k++) { - i = def->sorted_args[k]; - arg = args[i]; - arg_ct = &def->args_ct[i]; - ts = &s->temps[arg]; - if (arg_ct->ct & TCG_CT_ALIAS) { - reg = new_args[arg_ct->alias_index]; - } else { - /* if fixed register, we try to use it */ - reg = ts->reg; - if (ts->fixed_reg && - tcg_regset_test_reg(arg_ct->u.regs, reg)) { - goto oarg_end; - } - reg = tcg_reg_alloc(s, arg_ct->u.regs, allocated_regs); - } - tcg_regset_set_reg(allocated_regs, reg); - /* if a fixed register is used, then a move will be done afterwards */ - if (!ts->fixed_reg) { - if (ts->val_type == TEMP_VAL_REG) - s->reg_to_temp[ts->reg] = -1; - ts->val_type = TEMP_VAL_REG; - ts->reg = reg; - /* temp value is modified, so the value kept in memory is - potentially not the same */ - ts->mem_coherent = 0; - s->reg_to_temp[reg] = arg; - } - oarg_end: - new_args[i] = reg; - } - } - - /* emit instruction */ - tcg_out_op(s, opc, new_args, const_args); - - /* move the outputs in the correct register if needed */ - for(i = 0; i < nb_oargs; i++) { - ts = &s->temps[args[i]]; - reg = new_args[i]; - if (ts->fixed_reg && ts->reg != reg) { - tcg_out_mov(s, ts->reg, reg); - } - } -} - -#ifdef TCG_TARGET_STACK_GROWSUP -#define STACK_DIR(x) (-(x)) -#else -#define STACK_DIR(x) (x) -#endif - -static int tcg_reg_alloc_call(TCGContext *s, const TCGOpDef *def, - int opc, const TCGArg *args, - unsigned int dead_iargs) -{ - int nb_iargs, nb_oargs, flags, nb_regs, i, reg, nb_params; - TCGArg arg, func_arg; - TCGTemp *ts; - tcg_target_long stack_offset, call_stack_size, func_addr; - int const_func_arg, allocate_args; - TCGRegSet allocated_regs; - const TCGArgConstraint *arg_ct; - - arg = *args++; - - nb_oargs = arg >> 16; - nb_iargs = arg & 0xffff; - nb_params = nb_iargs - 1; - - flags = args[nb_oargs + nb_iargs]; - - nb_regs = tcg_target_get_call_iarg_regs_count(flags); - if (nb_regs > nb_params) - nb_regs = nb_params; - - /* assign stack slots first */ - /* XXX: preallocate call stack */ - call_stack_size = (nb_params - nb_regs) * sizeof(tcg_target_long); - call_stack_size = (call_stack_size + TCG_TARGET_STACK_ALIGN - 1) & - ~(TCG_TARGET_STACK_ALIGN - 1); - allocate_args = (call_stack_size > TCG_STATIC_CALL_ARGS_SIZE); - if (allocate_args) { - tcg_out_addi(s, TCG_REG_CALL_STACK, -STACK_DIR(call_stack_size)); - } - - stack_offset = TCG_TARGET_CALL_STACK_OFFSET; - for(i = nb_regs; i < nb_params; i++) { - arg = args[nb_oargs + i]; -#ifdef TCG_TARGET_STACK_GROWSUP - stack_offset -= sizeof(tcg_target_long); -#endif - if (arg != TCG_CALL_DUMMY_ARG) { - ts = &s->temps[arg]; - if (ts->val_type == TEMP_VAL_REG) { - tcg_out_st(s, ts->type, ts->reg, TCG_REG_CALL_STACK, stack_offset); - } else if (ts->val_type == TEMP_VAL_MEM) { - reg = tcg_reg_alloc(s, tcg_target_available_regs[ts->type], - s->reserved_regs); - /* XXX: not correct if reading values from the stack */ - tcg_out_ld(s, ts->type, reg, ts->mem_reg, ts->mem_offset); - tcg_out_st(s, ts->type, reg, TCG_REG_CALL_STACK, stack_offset); - } else if (ts->val_type == TEMP_VAL_CONST) { - reg = tcg_reg_alloc(s, tcg_target_available_regs[ts->type], - s->reserved_regs); - /* XXX: sign extend may be needed on some targets */ - tcg_out_movi(s, ts->type, reg, ts->val); - tcg_out_st(s, ts->type, reg, TCG_REG_CALL_STACK, stack_offset); - } else { - tcg_abort(); - } - } -#ifndef TCG_TARGET_STACK_GROWSUP - stack_offset += sizeof(tcg_target_long); -#endif - } - - /* assign input registers */ - tcg_regset_set(allocated_regs, s->reserved_regs); - for(i = 0; i < nb_regs; i++) { - arg = args[nb_oargs + i]; - if (arg != TCG_CALL_DUMMY_ARG) { - ts = &s->temps[arg]; - reg = tcg_target_call_iarg_regs[i]; - tcg_reg_free(s, reg); - if (ts->val_type == TEMP_VAL_REG) { - if (ts->reg != reg) { - tcg_out_mov(s, reg, ts->reg); - } - } else if (ts->val_type == TEMP_VAL_MEM) { - tcg_out_ld(s, ts->type, reg, ts->mem_reg, ts->mem_offset); - } else if (ts->val_type == TEMP_VAL_CONST) { - /* XXX: sign extend ? */ - tcg_out_movi(s, ts->type, reg, ts->val); - } else { - tcg_abort(); - } - tcg_regset_set_reg(allocated_regs, reg); - } - } - - /* assign function address */ - func_arg = args[nb_oargs + nb_iargs - 1]; - arg_ct = &def->args_ct[0]; - ts = &s->temps[func_arg]; - func_addr = ts->val; - const_func_arg = 0; - if (ts->val_type == TEMP_VAL_MEM) { - reg = tcg_reg_alloc(s, arg_ct->u.regs, allocated_regs); - tcg_out_ld(s, ts->type, reg, ts->mem_reg, ts->mem_offset); - func_arg = reg; - tcg_regset_set_reg(allocated_regs, reg); - } else if (ts->val_type == TEMP_VAL_REG) { - reg = ts->reg; - if (!tcg_regset_test_reg(arg_ct->u.regs, reg)) { - reg = tcg_reg_alloc(s, arg_ct->u.regs, allocated_regs); - tcg_out_mov(s, reg, ts->reg); - } - func_arg = reg; - tcg_regset_set_reg(allocated_regs, reg); - } else if (ts->val_type == TEMP_VAL_CONST) { - if (tcg_target_const_match(func_addr, arg_ct)) { - const_func_arg = 1; - func_arg = func_addr; - } else { - reg = tcg_reg_alloc(s, arg_ct->u.regs, allocated_regs); - tcg_out_movi(s, ts->type, reg, func_addr); - func_arg = reg; - tcg_regset_set_reg(allocated_regs, reg); - } - } else { - tcg_abort(); - } - - - /* mark dead temporaries and free the associated registers */ - for(i = 0; i < nb_iargs; i++) { - arg = args[nb_oargs + i]; - if (IS_DEAD_IARG(i)) { - ts = &s->temps[arg]; - if (!ts->fixed_reg) { - if (ts->val_type == TEMP_VAL_REG) - s->reg_to_temp[ts->reg] = -1; - ts->val_type = TEMP_VAL_DEAD; - } - } - } - - /* clobber call registers */ - for(reg = 0; reg < TCG_TARGET_NB_REGS; reg++) { - if (tcg_regset_test_reg(tcg_target_call_clobber_regs, reg)) { - tcg_reg_free(s, reg); - } - } - - /* store globals and free associated registers (we assume the call - can modify any global. */ - if (!(flags & TCG_CALL_CONST)) { - save_globals(s, allocated_regs); - } - - tcg_out_op(s, opc, &func_arg, &const_func_arg); - - if (allocate_args) { - tcg_out_addi(s, TCG_REG_CALL_STACK, STACK_DIR(call_stack_size)); - } - - /* assign output registers and emit moves if needed */ - for(i = 0; i < nb_oargs; i++) { - arg = args[i]; - ts = &s->temps[arg]; - reg = tcg_target_call_oarg_regs[i]; - assert(s->reg_to_temp[reg] == -1); - if (ts->fixed_reg) { - if (ts->reg != reg) { - tcg_out_mov(s, ts->reg, reg); - } - } else { - if (ts->val_type == TEMP_VAL_REG) - s->reg_to_temp[ts->reg] = -1; - ts->val_type = TEMP_VAL_REG; - ts->reg = reg; - ts->mem_coherent = 0; - s->reg_to_temp[reg] = arg; - } - } - - return nb_iargs + nb_oargs + def->nb_cargs + 1; -} - -#ifdef CONFIG_PROFILER - -static int64_t tcg_table_op_count[NB_OPS]; - -static void dump_op_count(void) -{ - int i; - FILE *f; - f = fopen("/tmp/op.log", "w"); - for(i = INDEX_op_end; i < NB_OPS; i++) { - fprintf(f, "%s %" PRId64 "\n", tcg_op_defs[i].name, tcg_table_op_count[i]); - } - fclose(f); -} -#endif - - -static inline int tcg_gen_code_common(TCGContext *s, uint8_t *gen_code_buf, - long search_pc) -{ - int opc, op_index; - const TCGOpDef *def; - unsigned int dead_iargs; - const TCGArg *args; - -#ifdef DEBUG_DISAS - if (unlikely(qemu_loglevel_mask(CPU_LOG_TB_OP))) { - qemu_log("OP:\n"); - tcg_dump_ops(s, logfile); - qemu_log("\n"); - } -#endif - -#ifdef CONFIG_PROFILER - s->la_time -= profile_getclock(); -#endif - tcg_liveness_analysis(s); -#ifdef CONFIG_PROFILER - s->la_time += profile_getclock(); -#endif - -#ifdef DEBUG_DISAS - if (unlikely(qemu_loglevel_mask(CPU_LOG_TB_OP_OPT))) { - qemu_log("OP after liveness analysis:\n"); - tcg_dump_ops(s, logfile); - qemu_log("\n"); - } -#endif - - tcg_reg_alloc_start(s); - - s->code_buf = gen_code_buf; - s->code_ptr = gen_code_buf; - - args = gen_opparam_buf; - op_index = 0; - - for(;;) { - opc = gen_opc_buf[op_index]; -#ifdef CONFIG_PROFILER - tcg_table_op_count[opc]++; -#endif - def = &tcg_op_defs[opc]; -#if 0 - printf("%s: %d %d %d\n", def->name, - def->nb_oargs, def->nb_iargs, def->nb_cargs); - // dump_regs(s); -#endif - switch(opc) { - case INDEX_op_mov_i32: -#if TCG_TARGET_REG_BITS == 64 - case INDEX_op_mov_i64: -#endif - dead_iargs = s->op_dead_iargs[op_index]; - tcg_reg_alloc_mov(s, def, args, dead_iargs); - break; - case INDEX_op_movi_i32: -#if TCG_TARGET_REG_BITS == 64 - case INDEX_op_movi_i64: -#endif - tcg_reg_alloc_movi(s, args); - break; - case INDEX_op_debug_insn_start: - /* debug instruction */ - break; - case INDEX_op_nop: - case INDEX_op_nop1: - case INDEX_op_nop2: - case INDEX_op_nop3: - break; - case INDEX_op_nopn: - args += args[0]; - goto next; - case INDEX_op_discard: - { - TCGTemp *ts; - ts = &s->temps[args[0]]; - /* mark the temporary as dead */ - if (!ts->fixed_reg) { - if (ts->val_type == TEMP_VAL_REG) - s->reg_to_temp[ts->reg] = -1; - ts->val_type = TEMP_VAL_DEAD; - } - } - break; - case INDEX_op_set_label: - tcg_reg_alloc_bb_end(s, s->reserved_regs); - tcg_out_label(s, args[0], (long)s->code_ptr); - break; - case INDEX_op_call: - dead_iargs = s->op_dead_iargs[op_index]; - args += tcg_reg_alloc_call(s, def, opc, args, dead_iargs); - goto next; - case INDEX_op_end: - goto the_end; - default: - /* Note: in order to speed up the code, it would be much - faster to have specialized register allocator functions for - some common argument patterns */ - dead_iargs = s->op_dead_iargs[op_index]; - tcg_reg_alloc_op(s, def, opc, args, dead_iargs); - break; - } - args += def->nb_args; - next: - if (search_pc >= 0 && search_pc < s->code_ptr - gen_code_buf) { - return op_index; - } - op_index++; -#ifndef NDEBUG - check_regs(s); -#endif - } - the_end: - return -1; -} - -int tcg_gen_code(TCGContext *s, uint8_t *gen_code_buf) -{ -#ifdef CONFIG_PROFILER - { - int n; - n = (gen_opc_ptr - gen_opc_buf); - s->op_count += n; - if (n > s->op_count_max) - s->op_count_max = n; - - s->temp_count += s->nb_temps; - if (s->nb_temps > s->temp_count_max) - s->temp_count_max = s->nb_temps; - } -#endif - - tcg_gen_code_common(s, gen_code_buf, -1); - - /* flush instruction cache */ - flush_icache_range((unsigned long)gen_code_buf, - (unsigned long)s->code_ptr); - return s->code_ptr - gen_code_buf; -} - -/* Return the index of the micro operation such as the pc after is < - offset bytes from the start of the TB. The contents of gen_code_buf must - not be changed, though writing the same values is ok. - Return -1 if not found. */ -int tcg_gen_code_search_pc(TCGContext *s, uint8_t *gen_code_buf, long offset) -{ - return tcg_gen_code_common(s, gen_code_buf, offset); -} - -#ifdef CONFIG_PROFILER -void tcg_dump_info(FILE *f, - int (*cpu_fprintf)(FILE *f, const char *fmt, ...)) -{ - TCGContext *s = &tcg_ctx; - int64_t tot; - - tot = s->interm_time + s->code_time; - cpu_fprintf(f, "JIT cycles %" PRId64 " (%0.3f s at 2.4 GHz)\n", - tot, tot / 2.4e9); - cpu_fprintf(f, "translated TBs %" PRId64 " (aborted=%" PRId64 " %0.1f%%)\n", - s->tb_count, - s->tb_count1 - s->tb_count, - s->tb_count1 ? (double)(s->tb_count1 - s->tb_count) / s->tb_count1 * 100.0 : 0); - cpu_fprintf(f, "avg ops/TB %0.1f max=%d\n", - s->tb_count ? (double)s->op_count / s->tb_count : 0, s->op_count_max); - cpu_fprintf(f, "deleted ops/TB %0.2f\n", - s->tb_count ? - (double)s->del_op_count / s->tb_count : 0); - cpu_fprintf(f, "avg temps/TB %0.2f max=%d\n", - s->tb_count ? - (double)s->temp_count / s->tb_count : 0, - s->temp_count_max); - - cpu_fprintf(f, "cycles/op %0.1f\n", - s->op_count ? (double)tot / s->op_count : 0); - cpu_fprintf(f, "cycles/in byte %0.1f\n", - s->code_in_len ? (double)tot / s->code_in_len : 0); - cpu_fprintf(f, "cycles/out byte %0.1f\n", - s->code_out_len ? (double)tot / s->code_out_len : 0); - if (tot == 0) - tot = 1; - cpu_fprintf(f, " gen_interm time %0.1f%%\n", - (double)s->interm_time / tot * 100.0); - cpu_fprintf(f, " gen_code time %0.1f%%\n", - (double)s->code_time / tot * 100.0); - cpu_fprintf(f, "liveness/code time %0.1f%%\n", - (double)s->la_time / (s->code_time ? s->code_time : 1) * 100.0); - cpu_fprintf(f, "cpu_restore count %" PRId64 "\n", - s->restore_count); - cpu_fprintf(f, " avg cycles %0.1f\n", - s->restore_count ? (double)s->restore_time / s->restore_count : 0); - - dump_op_count(); -} -#else -void tcg_dump_info(FILE *f, - int (*cpu_fprintf)(FILE *f, const char *fmt, ...)) -{ - cpu_fprintf(f, "[TCG profiler not compiled]\n"); -} -#endif diff --git a/qemu/qemu-git/tcg/.svn/text-base/tcg.h.svn-base b/qemu/qemu-git/tcg/.svn/text-base/tcg.h.svn-base deleted file mode 100644 index 121b17c..0000000 --- a/qemu/qemu-git/tcg/.svn/text-base/tcg.h.svn-base +++ /dev/null @@ -1,468 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2008 Fabrice Bellard - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ -#include "qemu-common.h" -#include "tcg-target.h" -#include "tcg-runtime.h" - -#if TCG_TARGET_REG_BITS == 32 -typedef int32_t tcg_target_long; -typedef uint32_t tcg_target_ulong; -#define TCG_PRIlx PRIx32 -#define TCG_PRIld PRId32 -#elif TCG_TARGET_REG_BITS == 64 -typedef int64_t tcg_target_long; -typedef uint64_t tcg_target_ulong; -#define TCG_PRIlx PRIx64 -#define TCG_PRIld PRId64 -#else -#error unsupported -#endif - -#if TCG_TARGET_NB_REGS <= 32 -typedef uint32_t TCGRegSet; -#elif TCG_TARGET_NB_REGS <= 64 -typedef uint64_t TCGRegSet; -#else -#error unsupported -#endif - -enum { -#define DEF(s, n, copy_size) INDEX_op_ ## s, -#include "tcg-opc.h" -#undef DEF - NB_OPS, -}; - -#define tcg_regset_clear(d) (d) = 0 -#define tcg_regset_set(d, s) (d) = (s) -#define tcg_regset_set32(d, reg, val32) (d) |= (val32) << (reg) -#define tcg_regset_set_reg(d, r) (d) |= 1L << (r) -#define tcg_regset_reset_reg(d, r) (d) &= ~(1L << (r)) -#define tcg_regset_test_reg(d, r) (((d) >> (r)) & 1) -#define tcg_regset_or(d, a, b) (d) = (a) | (b) -#define tcg_regset_and(d, a, b) (d) = (a) & (b) -#define tcg_regset_andnot(d, a, b) (d) = (a) & ~(b) -#define tcg_regset_not(d, a) (d) = ~(a) - -typedef struct TCGRelocation { - struct TCGRelocation *next; - int type; - uint8_t *ptr; - tcg_target_long addend; -} TCGRelocation; - -typedef struct TCGLabel { - int has_value; - union { - tcg_target_ulong value; - TCGRelocation *first_reloc; - } u; -} TCGLabel; - -typedef struct TCGPool { - struct TCGPool *next; - int size; - uint8_t data[0] __attribute__ ((aligned)); -} TCGPool; - -#define TCG_POOL_CHUNK_SIZE 32768 - -#define TCG_MAX_LABELS 512 - -#define TCG_MAX_TEMPS 512 - -/* when the size of the arguments of a called function is smaller than - this value, they are statically allocated in the TB stack frame */ -#define TCG_STATIC_CALL_ARGS_SIZE 128 - -typedef int TCGType; - -#define TCG_TYPE_I32 0 -#define TCG_TYPE_I64 1 -#define TCG_TYPE_COUNT 2 /* number of different types */ - -#if TCG_TARGET_REG_BITS == 32 -#define TCG_TYPE_PTR TCG_TYPE_I32 -#else -#define TCG_TYPE_PTR TCG_TYPE_I64 -#endif - -typedef tcg_target_ulong TCGArg; - -/* Define a type and accessor macros for varables. Using a struct is - nice because it gives some level of type safely. Ideally the compiler - be able to see through all this. However in practice this is not true, - expecially on targets with braindamaged ABIs (e.g. i386). - We use plain int by default to avoid this runtime overhead. - Users of tcg_gen_* don't need to know about any of this, and should - treat TCGv as an opaque type. - In additon we do typechecking for different types of variables. TCGv_i32 - and TCGv_i64 are 32/64-bit variables respectively. TCGv and TCGv_ptr - are aliases for target_ulong and host pointer sized values respectively. - */ - -#ifdef CONFIG_DEBUG_TCG -#define DEBUG_TCGV 1 -#endif - -#ifdef DEBUG_TCGV - -typedef struct -{ - int i32; -} TCGv_i32; - -typedef struct -{ - int i64; -} TCGv_i64; - -#define MAKE_TCGV_I32(i) __extension__ \ - ({ TCGv_i32 make_tcgv_tmp = {i}; make_tcgv_tmp;}) -#define MAKE_TCGV_I64(i) __extension__ \ - ({ TCGv_i64 make_tcgv_tmp = {i}; make_tcgv_tmp;}) -#define GET_TCGV_I32(t) ((t).i32) -#define GET_TCGV_I64(t) ((t).i64) -#if TCG_TARGET_REG_BITS == 32 -#define TCGV_LOW(t) MAKE_TCGV_I32(GET_TCGV_I64(t)) -#define TCGV_HIGH(t) MAKE_TCGV_I32(GET_TCGV_I64(t) + 1) -#endif - -#else /* !DEBUG_TCGV */ - -typedef int TCGv_i32; -typedef int TCGv_i64; -#define MAKE_TCGV_I32(x) (x) -#define MAKE_TCGV_I64(x) (x) -#define GET_TCGV_I32(t) (t) -#define GET_TCGV_I64(t) (t) - -#if TCG_TARGET_REG_BITS == 32 -#define TCGV_LOW(t) (t) -#define TCGV_HIGH(t) ((t) + 1) -#endif - -#endif /* DEBUG_TCGV */ - -#define TCGV_EQUAL_I32(a, b) (GET_TCGV_I32(a) == GET_TCGV_I32(b)) -#define TCGV_EQUAL_I64(a, b) (GET_TCGV_I64(a) == GET_TCGV_I64(b)) - -/* Dummy definition to avoid compiler warnings. */ -#define TCGV_UNUSED_I32(x) x = MAKE_TCGV_I32(-1) -#define TCGV_UNUSED_I64(x) x = MAKE_TCGV_I64(-1) - -/* call flags */ -#define TCG_CALL_TYPE_MASK 0x000f -#define TCG_CALL_TYPE_STD 0x0000 /* standard C call */ -#define TCG_CALL_TYPE_REGPARM_1 0x0001 /* i386 style regparm call (1 reg) */ -#define TCG_CALL_TYPE_REGPARM_2 0x0002 /* i386 style regparm call (2 regs) */ -#define TCG_CALL_TYPE_REGPARM 0x0003 /* i386 style regparm call (3 regs) */ -/* A pure function only reads its arguments and TCG global variables - and cannot raise exceptions. Hence a call to a pure function can be - safely suppressed if the return value is not used. */ -#define TCG_CALL_PURE 0x0010 -/* A const function only reads its arguments and does not use TCG - global variables. Hence a call to such a function does not - save TCG global variables back to their canonical location. */ -#define TCG_CALL_CONST 0x0020 - -/* used to align parameters */ -#define TCG_CALL_DUMMY_TCGV MAKE_TCGV_I32(-1) -#define TCG_CALL_DUMMY_ARG ((TCGArg)(-1)) - -typedef enum { - TCG_COND_EQ, - TCG_COND_NE, - TCG_COND_LT, - TCG_COND_GE, - TCG_COND_LE, - TCG_COND_GT, - /* unsigned */ - TCG_COND_LTU, - TCG_COND_GEU, - TCG_COND_LEU, - TCG_COND_GTU, -} TCGCond; - -static inline TCGCond tcg_unsigned_cond(TCGCond c) -{ - return (c >= TCG_COND_LT && c <= TCG_COND_GT ? c + 4 : c); -} - -#define TEMP_VAL_DEAD 0 -#define TEMP_VAL_REG 1 -#define TEMP_VAL_MEM 2 -#define TEMP_VAL_CONST 3 - -/* XXX: optimize memory layout */ -typedef struct TCGTemp { - TCGType base_type; - TCGType type; - int val_type; - int reg; - tcg_target_long val; - int mem_reg; - tcg_target_long mem_offset; - unsigned int fixed_reg:1; - unsigned int mem_coherent:1; - unsigned int mem_allocated:1; - unsigned int temp_local:1; /* If true, the temp is saved accross - basic blocks. Otherwise, it is not - preserved accross basic blocks. */ - unsigned int temp_allocated:1; /* never used for code gen */ - /* index of next free temp of same base type, -1 if end */ - int next_free_temp; - const char *name; -} TCGTemp; - -typedef struct TCGHelperInfo { - tcg_target_ulong func; - const char *name; -} TCGHelperInfo; - -typedef struct TCGContext TCGContext; - -struct TCGContext { - uint8_t *pool_cur, *pool_end; - TCGPool *pool_first, *pool_current; - TCGLabel *labels; - int nb_labels; - TCGTemp *temps; /* globals first, temps after */ - int nb_globals; - int nb_temps; - /* index of free temps, -1 if none */ - int first_free_temp[TCG_TYPE_COUNT * 2]; - - /* goto_tb support */ - uint8_t *code_buf; - unsigned long *tb_next; - uint16_t *tb_next_offset; - uint16_t *tb_jmp_offset; /* != NULL if USE_DIRECT_JUMP */ - - /* liveness analysis */ - uint16_t *op_dead_iargs; /* for each operation, each bit tells if the - corresponding input argument is dead */ - - /* tells in which temporary a given register is. It does not take - into account fixed registers */ - int reg_to_temp[TCG_TARGET_NB_REGS]; - TCGRegSet reserved_regs; - tcg_target_long current_frame_offset; - tcg_target_long frame_start; - tcg_target_long frame_end; - int frame_reg; - - uint8_t *code_ptr; - TCGTemp static_temps[TCG_MAX_TEMPS]; - - TCGHelperInfo *helpers; - int nb_helpers; - int allocated_helpers; - int helpers_sorted; - -#ifdef CONFIG_PROFILER - /* profiling info */ - int64_t tb_count1; - int64_t tb_count; - int64_t op_count; /* total insn count */ - int op_count_max; /* max insn per TB */ - int64_t temp_count; - int temp_count_max; - int64_t del_op_count; - int64_t code_in_len; - int64_t code_out_len; - int64_t interm_time; - int64_t code_time; - int64_t la_time; - int64_t restore_count; - int64_t restore_time; -#endif -}; - -extern TCGContext tcg_ctx; -extern uint16_t *gen_opc_ptr; -extern TCGArg *gen_opparam_ptr; -extern uint16_t gen_opc_buf[]; -extern TCGArg gen_opparam_buf[]; - -/* pool based memory allocation */ - -void *tcg_malloc_internal(TCGContext *s, int size); -void tcg_pool_reset(TCGContext *s); -void tcg_pool_delete(TCGContext *s); - -static inline void *tcg_malloc(int size) -{ - TCGContext *s = &tcg_ctx; - uint8_t *ptr, *ptr_end; - size = (size + sizeof(long) - 1) & ~(sizeof(long) - 1); - ptr = s->pool_cur; - ptr_end = ptr + size; - if (unlikely(ptr_end > s->pool_end)) { - return tcg_malloc_internal(&tcg_ctx, size); - } else { - s->pool_cur = ptr_end; - return ptr; - } -} - -void tcg_context_init(TCGContext *s); -void tcg_func_start(TCGContext *s); - -int tcg_gen_code(TCGContext *s, uint8_t *gen_code_buf); -int tcg_gen_code_search_pc(TCGContext *s, uint8_t *gen_code_buf, long offset); - -void tcg_set_frame(TCGContext *s, int reg, - tcg_target_long start, tcg_target_long size); - -TCGv_i32 tcg_global_reg_new_i32(int reg, const char *name); -TCGv_i32 tcg_global_mem_new_i32(int reg, tcg_target_long offset, - const char *name); -TCGv_i32 tcg_temp_new_internal_i32(int temp_local); -static inline TCGv_i32 tcg_temp_new_i32(void) -{ - return tcg_temp_new_internal_i32(0); -} -static inline TCGv_i32 tcg_temp_local_new_i32(void) -{ - return tcg_temp_new_internal_i32(1); -} -void tcg_temp_free_i32(TCGv_i32 arg); -char *tcg_get_arg_str_i32(TCGContext *s, char *buf, int buf_size, TCGv_i32 arg); - -TCGv_i64 tcg_global_reg_new_i64(int reg, const char *name); -TCGv_i64 tcg_global_mem_new_i64(int reg, tcg_target_long offset, - const char *name); -TCGv_i64 tcg_temp_new_internal_i64(int temp_local); -static inline TCGv_i64 tcg_temp_new_i64(void) -{ - return tcg_temp_new_internal_i64(0); -} -static inline TCGv_i64 tcg_temp_local_new_i64(void) -{ - return tcg_temp_new_internal_i64(1); -} -void tcg_temp_free_i64(TCGv_i64 arg); -char *tcg_get_arg_str_i64(TCGContext *s, char *buf, int buf_size, TCGv_i64 arg); - -void tcg_dump_info(FILE *f, - int (*cpu_fprintf)(FILE *f, const char *fmt, ...)); - -#define TCG_CT_ALIAS 0x80 -#define TCG_CT_IALIAS 0x40 -#define TCG_CT_REG 0x01 -#define TCG_CT_CONST 0x02 /* any constant of register size */ - -typedef struct TCGArgConstraint { - uint16_t ct; - uint8_t alias_index; - union { - TCGRegSet regs; - } u; -} TCGArgConstraint; - -#define TCG_MAX_OP_ARGS 16 - -#define TCG_OPF_BB_END 0x01 /* instruction defines the end of a basic - block */ -#define TCG_OPF_CALL_CLOBBER 0x02 /* instruction clobbers call registers - and potentially update globals. */ -#define TCG_OPF_SIDE_EFFECTS 0x04 /* instruction has side effects : it - cannot be removed if its output - are not used */ - -typedef struct TCGOpDef { - const char *name; - uint8_t nb_oargs, nb_iargs, nb_cargs, nb_args; - uint8_t flags; - uint16_t copy_size; - TCGArgConstraint *args_ct; - int *sorted_args; -} TCGOpDef; - -typedef struct TCGTargetOpDef { - int op; - const char *args_ct_str[TCG_MAX_OP_ARGS]; -} TCGTargetOpDef; - -void tcg_target_init(TCGContext *s); -void tcg_target_qemu_prologue(TCGContext *s); - -#define tcg_abort() \ -do {\ - fprintf(stderr, "%s:%d: tcg fatal error\n", __FILE__, __LINE__);\ - abort();\ -} while (0) - -void tcg_add_target_add_op_defs(const TCGTargetOpDef *tdefs); - -#if TCG_TARGET_REG_BITS == 32 -#define tcg_const_ptr tcg_const_i32 -#define tcg_add_ptr tcg_add_i32 -#define tcg_sub_ptr tcg_sub_i32 -#define TCGv_ptr TCGv_i32 -#define GET_TCGV_PTR GET_TCGV_I32 -#define tcg_global_reg_new_ptr tcg_global_reg_new_i32 -#define tcg_global_mem_new_ptr tcg_global_mem_new_i32 -#define tcg_temp_new_ptr tcg_temp_new_i32 -#define tcg_temp_free_ptr tcg_temp_free_i32 -#else -#define tcg_const_ptr tcg_const_i64 -#define tcg_add_ptr tcg_add_i64 -#define tcg_sub_ptr tcg_sub_i64 -#define TCGv_ptr TCGv_i64 -#define GET_TCGV_PTR GET_TCGV_I64 -#define tcg_global_reg_new_ptr tcg_global_reg_new_i64 -#define tcg_global_mem_new_ptr tcg_global_mem_new_i64 -#define tcg_temp_new_ptr tcg_temp_new_i64 -#define tcg_temp_free_ptr tcg_temp_free_i64 -#endif - -void tcg_gen_callN(TCGContext *s, TCGv_ptr func, unsigned int flags, - int sizemask, TCGArg ret, int nargs, TCGArg *args); - -void tcg_gen_shifti_i64(TCGv_i64 ret, TCGv_i64 arg1, - int c, int right, int arith); - -/* only used for debugging purposes */ -void tcg_register_helper(void *func, const char *name); -const char *tcg_helper_get_name(TCGContext *s, void *func); -void tcg_dump_ops(TCGContext *s, FILE *outfile); - -void dump_ops(const uint16_t *opc_buf, const TCGArg *opparam_buf); -TCGv_i32 tcg_const_i32(int32_t val); -TCGv_i64 tcg_const_i64(int64_t val); -TCGv_i32 tcg_const_local_i32(int32_t val); -TCGv_i64 tcg_const_local_i64(int64_t val); - -void tcg_out_reloc(TCGContext *s, uint8_t *code_ptr, int type, - int label_index, long addend); - -extern uint8_t code_gen_prologue[]; -#if defined(_ARCH_PPC) && !defined(_ARCH_PPC64) -#define tcg_qemu_tb_exec(tb_ptr) \ - ((long REGPARM __attribute__ ((longcall)) (*)(void *))code_gen_prologue)(tb_ptr) -#else -#define tcg_qemu_tb_exec(tb_ptr) ((long REGPARM (*)(void *))code_gen_prologue)(tb_ptr) -#endif diff --git a/qemu/qemu-git/tcg/arm/.svn/all-wcprops b/qemu/qemu-git/tcg/arm/.svn/all-wcprops deleted file mode 100644 index 69b717b..0000000 --- a/qemu/qemu-git/tcg/arm/.svn/all-wcprops +++ /dev/null @@ -1,17 +0,0 @@ -K 25 -svn:wc:ra_dav:version-url -V 47 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/arm -END -tcg-target.c -K 25 -svn:wc:ra_dav:version-url -V 60 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/arm/tcg-target.c -END -tcg-target.h -K 25 -svn:wc:ra_dav:version-url -V 60 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/arm/tcg-target.h -END diff --git a/qemu/qemu-git/tcg/arm/.svn/entries b/qemu/qemu-git/tcg/arm/.svn/entries deleted file mode 100644 index b18fb29..0000000 --- a/qemu/qemu-git/tcg/arm/.svn/entries +++ /dev/null @@ -1,96 +0,0 @@ -10 - -dir -11 -http://svn.code.sf.net/p/x49gp/code/qemu/qemu-git/tcg/arm -http://svn.code.sf.net/p/x49gp/code - - - -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - -481df3bd-3408-496c-b7de-451e46197bb5 - -tcg-target.c -file - - - - -2013-08-23T00:54:47.000000Z -98deb0581c939945cb5a0611f98a6a5e -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -54714 - -tcg-target.h -file - - - - -2013-08-23T00:54:47.000000Z -2f84ffc289d4ac8d17ea1350d0dcbc0e -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -2650 - diff --git a/qemu/qemu-git/tcg/arm/.svn/text-base/tcg-target.c.svn-base b/qemu/qemu-git/tcg/arm/.svn/text-base/tcg-target.c.svn-base deleted file mode 100644 index f8d626d..0000000 --- a/qemu/qemu-git/tcg/arm/.svn/text-base/tcg-target.c.svn-base +++ /dev/null @@ -1,1708 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2008 Andrzej Zaborowski - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ - -#ifndef NDEBUG -static const char * const tcg_target_reg_names[TCG_TARGET_NB_REGS] = { - "%r0", - "%r1", - "%r2", - "%r3", - "%r4", - "%r5", - "%r6", - "%r7", - "%r8", - "%r9", - "%r10", - "%r11", - "%r12", - "%r13", - "%r14", -}; -#endif - -static const int tcg_target_reg_alloc_order[] = { - TCG_REG_R0, - TCG_REG_R1, - TCG_REG_R2, - TCG_REG_R3, - TCG_REG_R4, - TCG_REG_R5, - TCG_REG_R6, - TCG_REG_R7, - TCG_REG_R8, - TCG_REG_R9, - TCG_REG_R10, - TCG_REG_R11, - TCG_REG_R12, - TCG_REG_R13, - TCG_REG_R14, -}; - -static const int tcg_target_call_iarg_regs[4] = { - TCG_REG_R0, TCG_REG_R1, TCG_REG_R2, TCG_REG_R3 -}; -static const int tcg_target_call_oarg_regs[2] = { - TCG_REG_R0, TCG_REG_R1 -}; - -static void patch_reloc(uint8_t *code_ptr, int type, - tcg_target_long value, tcg_target_long addend) -{ - switch (type) { - case R_ARM_ABS32: - *(uint32_t *) code_ptr = value; - break; - - case R_ARM_CALL: - case R_ARM_JUMP24: - default: - tcg_abort(); - - case R_ARM_PC24: - *(uint32_t *) code_ptr = ((*(uint32_t *) code_ptr) & 0xff000000) | - (((value - ((tcg_target_long) code_ptr + 8)) >> 2) & 0xffffff); - break; - } -} - -/* maximum number of register used for input function arguments */ -static inline int tcg_target_get_call_iarg_regs_count(int flags) -{ - return 4; -} - -/* parse target specific constraints */ -static int target_parse_constraint(TCGArgConstraint *ct, const char **pct_str) -{ - const char *ct_str; - - ct_str = *pct_str; - switch (ct_str[0]) { - case 'I': - ct->ct |= TCG_CT_CONST_ARM; - break; - - case 'r': -#ifndef CONFIG_SOFTMMU - case 'd': - case 'D': - case 'x': - case 'X': -#endif - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, (1 << TCG_TARGET_NB_REGS) - 1); - break; - -#ifdef CONFIG_SOFTMMU - /* qemu_ld/st inputs (unless 'X', 'd' or 'D') */ - case 'x': - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, (1 << TCG_TARGET_NB_REGS) - 1); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R0); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R1); - break; - - /* qemu_ld64 data_reg */ - case 'd': - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, (1 << TCG_TARGET_NB_REGS) - 1); - /* r1 is still needed to load data_reg2, so don't use it. */ - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R1); - break; - - /* qemu_ld/st64 data_reg2 */ - case 'D': - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, (1 << TCG_TARGET_NB_REGS) - 1); - /* r0, r1 and optionally r2 will be overwritten by the address - * and the low word of data, so don't use these. */ - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R0); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R1); -# if TARGET_LONG_BITS == 64 - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R2); -# endif - break; - -# if TARGET_LONG_BITS == 64 - /* qemu_ld/st addr_reg2 */ - case 'X': - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, (1 << TCG_TARGET_NB_REGS) - 1); - /* r0 will be overwritten by the low word of base, so don't use it. */ - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R0); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R1); - break; -# endif -#endif - - case '1': - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, (1 << TCG_TARGET_NB_REGS) - 1); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R0); - break; - - case '2': - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, (1 << TCG_TARGET_NB_REGS) - 1); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R0); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R1); - break; - - default: - return -1; - } - ct_str++; - *pct_str = ct_str; - - return 0; -} - -static inline uint32_t rotl(uint32_t val, int n) -{ - return (val << n) | (val >> (32 - n)); -} - -/* ARM immediates for ALU instructions are made of an unsigned 8-bit - right-rotated by an even amount between 0 and 30. */ -static inline int encode_imm(uint32_t imm) -{ - int shift; - - /* simple case, only lower bits */ - if ((imm & ~0xff) == 0) - return 0; - /* then try a simple even shift */ - shift = ctz32(imm) & ~1; - if (((imm >> shift) & ~0xff) == 0) - return 32 - shift; - /* now try harder with rotations */ - if ((rotl(imm, 2) & ~0xff) == 0) - return 2; - if ((rotl(imm, 4) & ~0xff) == 0) - return 4; - if ((rotl(imm, 6) & ~0xff) == 0) - return 6; - /* imm can't be encoded */ - return -1; -} - -static inline int check_fit_imm(uint32_t imm) -{ - return encode_imm(imm) >= 0; -} - -/* Test if a constant matches the constraint. - * TODO: define constraints for: - * - * ldr/str offset: between -0xfff and 0xfff - * ldrh/strh offset: between -0xff and 0xff - * mov operand2: values represented with x << (2 * y), x < 0x100 - * add, sub, eor...: ditto - */ -static inline int tcg_target_const_match(tcg_target_long val, - const TCGArgConstraint *arg_ct) -{ - int ct; - ct = arg_ct->ct; - if (ct & TCG_CT_CONST) - return 1; - else if ((ct & TCG_CT_CONST_ARM) && check_fit_imm(val)) - return 1; - else - return 0; -} - -enum arm_data_opc_e { - ARITH_AND = 0x0, - ARITH_EOR = 0x1, - ARITH_SUB = 0x2, - ARITH_RSB = 0x3, - ARITH_ADD = 0x4, - ARITH_ADC = 0x5, - ARITH_SBC = 0x6, - ARITH_RSC = 0x7, - ARITH_TST = 0x8, - ARITH_CMP = 0xa, - ARITH_CMN = 0xb, - ARITH_ORR = 0xc, - ARITH_MOV = 0xd, - ARITH_BIC = 0xe, - ARITH_MVN = 0xf, -}; - -#define TO_CPSR(opc) \ - ((opc == ARITH_CMP || opc == ARITH_CMN || opc == ARITH_TST) << 20) - -#define SHIFT_IMM_LSL(im) (((im) << 7) | 0x00) -#define SHIFT_IMM_LSR(im) (((im) << 7) | 0x20) -#define SHIFT_IMM_ASR(im) (((im) << 7) | 0x40) -#define SHIFT_IMM_ROR(im) (((im) << 7) | 0x60) -#define SHIFT_REG_LSL(rs) (((rs) << 8) | 0x10) -#define SHIFT_REG_LSR(rs) (((rs) << 8) | 0x30) -#define SHIFT_REG_ASR(rs) (((rs) << 8) | 0x50) -#define SHIFT_REG_ROR(rs) (((rs) << 8) | 0x70) - -enum arm_cond_code_e { - COND_EQ = 0x0, - COND_NE = 0x1, - COND_CS = 0x2, /* Unsigned greater or equal */ - COND_CC = 0x3, /* Unsigned less than */ - COND_MI = 0x4, /* Negative */ - COND_PL = 0x5, /* Zero or greater */ - COND_VS = 0x6, /* Overflow */ - COND_VC = 0x7, /* No overflow */ - COND_HI = 0x8, /* Unsigned greater than */ - COND_LS = 0x9, /* Unsigned less or equal */ - COND_GE = 0xa, - COND_LT = 0xb, - COND_GT = 0xc, - COND_LE = 0xd, - COND_AL = 0xe, -}; - -static const uint8_t tcg_cond_to_arm_cond[10] = { - [TCG_COND_EQ] = COND_EQ, - [TCG_COND_NE] = COND_NE, - [TCG_COND_LT] = COND_LT, - [TCG_COND_GE] = COND_GE, - [TCG_COND_LE] = COND_LE, - [TCG_COND_GT] = COND_GT, - /* unsigned */ - [TCG_COND_LTU] = COND_CC, - [TCG_COND_GEU] = COND_CS, - [TCG_COND_LEU] = COND_LS, - [TCG_COND_GTU] = COND_HI, -}; - -static inline void tcg_out_bx(TCGContext *s, int cond, int rn) -{ - tcg_out32(s, (cond << 28) | 0x012fff10 | rn); -} - -static inline void tcg_out_b(TCGContext *s, int cond, int32_t offset) -{ - tcg_out32(s, (cond << 28) | 0x0a000000 | - (((offset - 8) >> 2) & 0x00ffffff)); -} - -static inline void tcg_out_b_noaddr(TCGContext *s, int cond) -{ -#ifdef HOST_WORDS_BIGENDIAN - tcg_out8(s, (cond << 4) | 0x0a); - s->code_ptr += 3; -#else - s->code_ptr += 3; - tcg_out8(s, (cond << 4) | 0x0a); -#endif -} - -static inline void tcg_out_bl(TCGContext *s, int cond, int32_t offset) -{ - tcg_out32(s, (cond << 28) | 0x0b000000 | - (((offset - 8) >> 2) & 0x00ffffff)); -} - -static inline void tcg_out_dat_reg(TCGContext *s, - int cond, int opc, int rd, int rn, int rm, int shift) -{ - tcg_out32(s, (cond << 28) | (0 << 25) | (opc << 21) | TO_CPSR(opc) | - (rn << 16) | (rd << 12) | shift | rm); -} - -static inline void tcg_out_dat_reg2(TCGContext *s, - int cond, int opc0, int opc1, int rd0, int rd1, - int rn0, int rn1, int rm0, int rm1, int shift) -{ - if (rd0 == rn1 || rd0 == rm1) { - tcg_out32(s, (cond << 28) | (0 << 25) | (opc0 << 21) | (1 << 20) | - (rn0 << 16) | (8 << 12) | shift | rm0); - tcg_out32(s, (cond << 28) | (0 << 25) | (opc1 << 21) | - (rn1 << 16) | (rd1 << 12) | shift | rm1); - tcg_out_dat_reg(s, cond, ARITH_MOV, - rd0, 0, TCG_REG_R8, SHIFT_IMM_LSL(0)); - } else { - tcg_out32(s, (cond << 28) | (0 << 25) | (opc0 << 21) | (1 << 20) | - (rn0 << 16) | (rd0 << 12) | shift | rm0); - tcg_out32(s, (cond << 28) | (0 << 25) | (opc1 << 21) | - (rn1 << 16) | (rd1 << 12) | shift | rm1); - } -} - -static inline void tcg_out_dat_imm(TCGContext *s, - int cond, int opc, int rd, int rn, int im) -{ - tcg_out32(s, (cond << 28) | (1 << 25) | (opc << 21) | TO_CPSR(opc) | - (rn << 16) | (rd << 12) | im); -} - -static inline void tcg_out_movi32(TCGContext *s, - int cond, int rd, int32_t arg) -{ - int offset = (uint32_t) arg - ((uint32_t) s->code_ptr + 8); - - /* TODO: This is very suboptimal, we can easily have a constant - * pool somewhere after all the instructions. */ - - if (arg < 0 && arg > -0x100) - return tcg_out_dat_imm(s, cond, ARITH_MVN, rd, 0, (~arg) & 0xff); - - if (offset < 0x100 && offset > -0x100) - return offset >= 0 ? - tcg_out_dat_imm(s, cond, ARITH_ADD, rd, 15, offset) : - tcg_out_dat_imm(s, cond, ARITH_SUB, rd, 15, -offset); - -#ifdef __ARM_ARCH_7A__ - /* use movw/movt */ - /* movw */ - tcg_out32(s, (cond << 28) | 0x03000000 | (rd << 12) - | ((arg << 4) & 0x000f0000) | (arg & 0xfff)); - if (arg & 0xffff0000) - /* movt */ - tcg_out32(s, (cond << 28) | 0x03400000 | (rd << 12) - | ((arg >> 12) & 0x000f0000) | ((arg >> 16) & 0xfff)); -#else - tcg_out_dat_imm(s, cond, ARITH_MOV, rd, 0, arg & 0xff); - if (arg & 0x0000ff00) - tcg_out_dat_imm(s, cond, ARITH_ORR, rd, rd, - ((arg >> 8) & 0xff) | 0xc00); - if (arg & 0x00ff0000) - tcg_out_dat_imm(s, cond, ARITH_ORR, rd, rd, - ((arg >> 16) & 0xff) | 0x800); - if (arg & 0xff000000) - tcg_out_dat_imm(s, cond, ARITH_ORR, rd, rd, - ((arg >> 24) & 0xff) | 0x400); -#endif -} - -static inline void tcg_out_mul32(TCGContext *s, - int cond, int rd, int rs, int rm) -{ - if (rd != rm) - tcg_out32(s, (cond << 28) | (rd << 16) | (0 << 12) | - (rs << 8) | 0x90 | rm); - else if (rd != rs) - tcg_out32(s, (cond << 28) | (rd << 16) | (0 << 12) | - (rm << 8) | 0x90 | rs); - else { - tcg_out32(s, (cond << 28) | ( 8 << 16) | (0 << 12) | - (rs << 8) | 0x90 | rm); - tcg_out_dat_reg(s, cond, ARITH_MOV, - rd, 0, 8, SHIFT_IMM_LSL(0)); - } -} - -static inline void tcg_out_umull32(TCGContext *s, - int cond, int rd0, int rd1, int rs, int rm) -{ - if (rd0 != rm && rd1 != rm) - tcg_out32(s, (cond << 28) | 0x800090 | - (rd1 << 16) | (rd0 << 12) | (rs << 8) | rm); - else if (rd0 != rs && rd1 != rs) - tcg_out32(s, (cond << 28) | 0x800090 | - (rd1 << 16) | (rd0 << 12) | (rm << 8) | rs); - else { - tcg_out_dat_reg(s, cond, ARITH_MOV, - TCG_REG_R8, 0, rm, SHIFT_IMM_LSL(0)); - tcg_out32(s, (cond << 28) | 0x800098 | - (rd1 << 16) | (rd0 << 12) | (rs << 8)); - } -} - -static inline void tcg_out_smull32(TCGContext *s, - int cond, int rd0, int rd1, int rs, int rm) -{ - if (rd0 != rm && rd1 != rm) - tcg_out32(s, (cond << 28) | 0xc00090 | - (rd1 << 16) | (rd0 << 12) | (rs << 8) | rm); - else if (rd0 != rs && rd1 != rs) - tcg_out32(s, (cond << 28) | 0xc00090 | - (rd1 << 16) | (rd0 << 12) | (rm << 8) | rs); - else { - tcg_out_dat_reg(s, cond, ARITH_MOV, - TCG_REG_R8, 0, rm, SHIFT_IMM_LSL(0)); - tcg_out32(s, (cond << 28) | 0xc00098 | - (rd1 << 16) | (rd0 << 12) | (rs << 8)); - } -} - -static inline void tcg_out_ld32_12(TCGContext *s, int cond, - int rd, int rn, tcg_target_long im) -{ - if (im >= 0) - tcg_out32(s, (cond << 28) | 0x05900000 | - (rn << 16) | (rd << 12) | (im & 0xfff)); - else - tcg_out32(s, (cond << 28) | 0x05100000 | - (rn << 16) | (rd << 12) | ((-im) & 0xfff)); -} - -static inline void tcg_out_st32_12(TCGContext *s, int cond, - int rd, int rn, tcg_target_long im) -{ - if (im >= 0) - tcg_out32(s, (cond << 28) | 0x05800000 | - (rn << 16) | (rd << 12) | (im & 0xfff)); - else - tcg_out32(s, (cond << 28) | 0x05000000 | - (rn << 16) | (rd << 12) | ((-im) & 0xfff)); -} - -static inline void tcg_out_ld32_r(TCGContext *s, int cond, - int rd, int rn, int rm) -{ - tcg_out32(s, (cond << 28) | 0x07900000 | - (rn << 16) | (rd << 12) | rm); -} - -static inline void tcg_out_st32_r(TCGContext *s, int cond, - int rd, int rn, int rm) -{ - tcg_out32(s, (cond << 28) | 0x07800000 | - (rn << 16) | (rd << 12) | rm); -} - -/* Register pre-increment with base writeback. */ -static inline void tcg_out_ld32_rwb(TCGContext *s, int cond, - int rd, int rn, int rm) -{ - tcg_out32(s, (cond << 28) | 0x07b00000 | - (rn << 16) | (rd << 12) | rm); -} - -static inline void tcg_out_st32_rwb(TCGContext *s, int cond, - int rd, int rn, int rm) -{ - tcg_out32(s, (cond << 28) | 0x07a00000 | - (rn << 16) | (rd << 12) | rm); -} - -static inline void tcg_out_ld16u_8(TCGContext *s, int cond, - int rd, int rn, tcg_target_long im) -{ - if (im >= 0) - tcg_out32(s, (cond << 28) | 0x01d000b0 | - (rn << 16) | (rd << 12) | - ((im & 0xf0) << 4) | (im & 0xf)); - else - tcg_out32(s, (cond << 28) | 0x015000b0 | - (rn << 16) | (rd << 12) | - (((-im) & 0xf0) << 4) | ((-im) & 0xf)); -} - -static inline void tcg_out_st16u_8(TCGContext *s, int cond, - int rd, int rn, tcg_target_long im) -{ - if (im >= 0) - tcg_out32(s, (cond << 28) | 0x01c000b0 | - (rn << 16) | (rd << 12) | - ((im & 0xf0) << 4) | (im & 0xf)); - else - tcg_out32(s, (cond << 28) | 0x014000b0 | - (rn << 16) | (rd << 12) | - (((-im) & 0xf0) << 4) | ((-im) & 0xf)); -} - -static inline void tcg_out_ld16u_r(TCGContext *s, int cond, - int rd, int rn, int rm) -{ - tcg_out32(s, (cond << 28) | 0x019000b0 | - (rn << 16) | (rd << 12) | rm); -} - -static inline void tcg_out_st16u_r(TCGContext *s, int cond, - int rd, int rn, int rm) -{ - tcg_out32(s, (cond << 28) | 0x018000b0 | - (rn << 16) | (rd << 12) | rm); -} - -static inline void tcg_out_ld16s_8(TCGContext *s, int cond, - int rd, int rn, tcg_target_long im) -{ - if (im >= 0) - tcg_out32(s, (cond << 28) | 0x01d000f0 | - (rn << 16) | (rd << 12) | - ((im & 0xf0) << 4) | (im & 0xf)); - else - tcg_out32(s, (cond << 28) | 0x015000f0 | - (rn << 16) | (rd << 12) | - (((-im) & 0xf0) << 4) | ((-im) & 0xf)); -} - -static inline void tcg_out_st16s_8(TCGContext *s, int cond, - int rd, int rn, tcg_target_long im) -{ - if (im >= 0) - tcg_out32(s, (cond << 28) | 0x01c000f0 | - (rn << 16) | (rd << 12) | - ((im & 0xf0) << 4) | (im & 0xf)); - else - tcg_out32(s, (cond << 28) | 0x014000f0 | - (rn << 16) | (rd << 12) | - (((-im) & 0xf0) << 4) | ((-im) & 0xf)); -} - -static inline void tcg_out_ld16s_r(TCGContext *s, int cond, - int rd, int rn, int rm) -{ - tcg_out32(s, (cond << 28) | 0x019000f0 | - (rn << 16) | (rd << 12) | rm); -} - -static inline void tcg_out_st16s_r(TCGContext *s, int cond, - int rd, int rn, int rm) -{ - tcg_out32(s, (cond << 28) | 0x018000f0 | - (rn << 16) | (rd << 12) | rm); -} - -static inline void tcg_out_ld8_12(TCGContext *s, int cond, - int rd, int rn, tcg_target_long im) -{ - if (im >= 0) - tcg_out32(s, (cond << 28) | 0x05d00000 | - (rn << 16) | (rd << 12) | (im & 0xfff)); - else - tcg_out32(s, (cond << 28) | 0x05500000 | - (rn << 16) | (rd << 12) | ((-im) & 0xfff)); -} - -static inline void tcg_out_st8_12(TCGContext *s, int cond, - int rd, int rn, tcg_target_long im) -{ - if (im >= 0) - tcg_out32(s, (cond << 28) | 0x05c00000 | - (rn << 16) | (rd << 12) | (im & 0xfff)); - else - tcg_out32(s, (cond << 28) | 0x05400000 | - (rn << 16) | (rd << 12) | ((-im) & 0xfff)); -} - -static inline void tcg_out_ld8_r(TCGContext *s, int cond, - int rd, int rn, int rm) -{ - tcg_out32(s, (cond << 28) | 0x07d00000 | - (rn << 16) | (rd << 12) | rm); -} - -static inline void tcg_out_st8_r(TCGContext *s, int cond, - int rd, int rn, int rm) -{ - tcg_out32(s, (cond << 28) | 0x07c00000 | - (rn << 16) | (rd << 12) | rm); -} - -static inline void tcg_out_ld8s_8(TCGContext *s, int cond, - int rd, int rn, tcg_target_long im) -{ - if (im >= 0) - tcg_out32(s, (cond << 28) | 0x01d000d0 | - (rn << 16) | (rd << 12) | - ((im & 0xf0) << 4) | (im & 0xf)); - else - tcg_out32(s, (cond << 28) | 0x015000d0 | - (rn << 16) | (rd << 12) | - (((-im) & 0xf0) << 4) | ((-im) & 0xf)); -} - -static inline void tcg_out_st8s_8(TCGContext *s, int cond, - int rd, int rn, tcg_target_long im) -{ - if (im >= 0) - tcg_out32(s, (cond << 28) | 0x01c000d0 | - (rn << 16) | (rd << 12) | - ((im & 0xf0) << 4) | (im & 0xf)); - else - tcg_out32(s, (cond << 28) | 0x014000d0 | - (rn << 16) | (rd << 12) | - (((-im) & 0xf0) << 4) | ((-im) & 0xf)); -} - -static inline void tcg_out_ld8s_r(TCGContext *s, int cond, - int rd, int rn, int rm) -{ - tcg_out32(s, (cond << 28) | 0x019000d0 | - (rn << 16) | (rd << 12) | rm); -} - -static inline void tcg_out_st8s_r(TCGContext *s, int cond, - int rd, int rn, int rm) -{ - tcg_out32(s, (cond << 28) | 0x018000d0 | - (rn << 16) | (rd << 12) | rm); -} - -static inline void tcg_out_ld32u(TCGContext *s, int cond, - int rd, int rn, int32_t offset) -{ - if (offset > 0xfff || offset < -0xfff) { - tcg_out_movi32(s, cond, TCG_REG_R8, offset); - tcg_out_ld32_r(s, cond, rd, rn, TCG_REG_R8); - } else - tcg_out_ld32_12(s, cond, rd, rn, offset); -} - -static inline void tcg_out_st32(TCGContext *s, int cond, - int rd, int rn, int32_t offset) -{ - if (offset > 0xfff || offset < -0xfff) { - tcg_out_movi32(s, cond, TCG_REG_R8, offset); - tcg_out_st32_r(s, cond, rd, rn, TCG_REG_R8); - } else - tcg_out_st32_12(s, cond, rd, rn, offset); -} - -static inline void tcg_out_ld16u(TCGContext *s, int cond, - int rd, int rn, int32_t offset) -{ - if (offset > 0xff || offset < -0xff) { - tcg_out_movi32(s, cond, TCG_REG_R8, offset); - tcg_out_ld16u_r(s, cond, rd, rn, TCG_REG_R8); - } else - tcg_out_ld16u_8(s, cond, rd, rn, offset); -} - -static inline void tcg_out_ld16s(TCGContext *s, int cond, - int rd, int rn, int32_t offset) -{ - if (offset > 0xff || offset < -0xff) { - tcg_out_movi32(s, cond, TCG_REG_R8, offset); - tcg_out_ld16s_r(s, cond, rd, rn, TCG_REG_R8); - } else - tcg_out_ld16s_8(s, cond, rd, rn, offset); -} - -static inline void tcg_out_st16u(TCGContext *s, int cond, - int rd, int rn, int32_t offset) -{ - if (offset > 0xff || offset < -0xff) { - tcg_out_movi32(s, cond, TCG_REG_R8, offset); - tcg_out_st16u_r(s, cond, rd, rn, TCG_REG_R8); - } else - tcg_out_st16u_8(s, cond, rd, rn, offset); -} - -static inline void tcg_out_ld8u(TCGContext *s, int cond, - int rd, int rn, int32_t offset) -{ - if (offset > 0xfff || offset < -0xfff) { - tcg_out_movi32(s, cond, TCG_REG_R8, offset); - tcg_out_ld8_r(s, cond, rd, rn, TCG_REG_R8); - } else - tcg_out_ld8_12(s, cond, rd, rn, offset); -} - -static inline void tcg_out_ld8s(TCGContext *s, int cond, - int rd, int rn, int32_t offset) -{ - if (offset > 0xff || offset < -0xff) { - tcg_out_movi32(s, cond, TCG_REG_R8, offset); - tcg_out_ld8s_r(s, cond, rd, rn, TCG_REG_R8); - } else - tcg_out_ld8s_8(s, cond, rd, rn, offset); -} - -static inline void tcg_out_st8u(TCGContext *s, int cond, - int rd, int rn, int32_t offset) -{ - if (offset > 0xfff || offset < -0xfff) { - tcg_out_movi32(s, cond, TCG_REG_R8, offset); - tcg_out_st8_r(s, cond, rd, rn, TCG_REG_R8); - } else - tcg_out_st8_12(s, cond, rd, rn, offset); -} - -static inline void tcg_out_goto(TCGContext *s, int cond, uint32_t addr) -{ - int32_t val; - - val = addr - (tcg_target_long) s->code_ptr; - if (val - 8 < 0x01fffffd && val - 8 > -0x01fffffd) - tcg_out_b(s, cond, val); - else { -#if 1 - tcg_abort(); -#else - if (cond == COND_AL) { - tcg_out_ld32_12(s, COND_AL, 15, 15, -4); - tcg_out32(s, addr); /* XXX: This is l->u.value, can we use it? */ - } else { - tcg_out_movi32(s, cond, TCG_REG_R8, val - 8); - tcg_out_dat_reg(s, cond, ARITH_ADD, - 15, 15, TCG_REG_R8, SHIFT_IMM_LSL(0)); - } -#endif - } -} - -static inline void tcg_out_call(TCGContext *s, int cond, uint32_t addr) -{ - int32_t val; - -#ifdef SAVE_LR - tcg_out_dat_reg(s, cond, ARITH_MOV, TCG_REG_R8, 0, 14, SHIFT_IMM_LSL(0)); -#endif - - val = addr - (tcg_target_long) s->code_ptr; - if (val < 0x01fffffd && val > -0x01fffffd) - tcg_out_bl(s, cond, val); - else { -#if 1 - tcg_abort(); -#else - if (cond == COND_AL) { - tcg_out_dat_imm(s, cond, ARITH_ADD, 14, 15, 4); - tcg_out_ld32_12(s, COND_AL, 15, 15, -4); - tcg_out32(s, addr); /* XXX: This is l->u.value, can we use it? */ - } else { - tcg_out_movi32(s, cond, TCG_REG_R9, addr); - tcg_out_dat_imm(s, cond, ARITH_MOV, 14, 0, 15); - tcg_out_bx(s, cond, TCG_REG_R9); - } -#endif - } - -#ifdef SAVE_LR - tcg_out_dat_reg(s, cond, ARITH_MOV, 14, 0, TCG_REG_R8, SHIFT_IMM_LSL(0)); -#endif -} - -static inline void tcg_out_callr(TCGContext *s, int cond, int arg) -{ -#ifdef SAVE_LR - tcg_out_dat_reg(s, cond, ARITH_MOV, TCG_REG_R8, 0, 14, SHIFT_IMM_LSL(0)); -#endif - /* TODO: on ARMv5 and ARMv6 replace with tcg_out_blx(s, cond, arg); */ - tcg_out_dat_reg(s, cond, ARITH_MOV, 14, 0, 15, SHIFT_IMM_LSL(0)); - tcg_out_bx(s, cond, arg); -#ifdef SAVE_LR - tcg_out_dat_reg(s, cond, ARITH_MOV, 14, 0, TCG_REG_R8, SHIFT_IMM_LSL(0)); -#endif -} - -static inline void tcg_out_goto_label(TCGContext *s, int cond, int label_index) -{ - TCGLabel *l = &s->labels[label_index]; - - if (l->has_value) - tcg_out_goto(s, cond, l->u.value); - else if (cond == COND_AL) { - tcg_out_ld32_12(s, COND_AL, 15, 15, -4); - tcg_out_reloc(s, s->code_ptr, R_ARM_ABS32, label_index, 31337); - s->code_ptr += 4; - } else { - /* Probably this should be preferred even for COND_AL... */ - tcg_out_reloc(s, s->code_ptr, R_ARM_PC24, label_index, 31337); - tcg_out_b_noaddr(s, cond); - } -} - -static void tcg_out_div_helper(TCGContext *s, int cond, const TCGArg *args, - void *helper_div, void *helper_rem, int shift) -{ - int div_reg = args[0]; - int rem_reg = args[1]; - - /* stmdb sp!, { r0 - r3, ip, lr } */ - /* (Note that we need an even number of registers as per EABI) */ - tcg_out32(s, (cond << 28) | 0x092d500f); - - tcg_out_dat_reg(s, cond, ARITH_MOV, 0, 0, args[2], SHIFT_IMM_LSL(0)); - tcg_out_dat_reg(s, cond, ARITH_MOV, 1, 0, args[3], SHIFT_IMM_LSL(0)); - tcg_out_dat_reg(s, cond, ARITH_MOV, 2, 0, args[4], SHIFT_IMM_LSL(0)); - tcg_out_dat_reg(s, cond, ARITH_MOV, 3, 0, 2, shift); - - tcg_out_call(s, cond, (uint32_t) helper_div); - tcg_out_dat_reg(s, cond, ARITH_MOV, 8, 0, 0, SHIFT_IMM_LSL(0)); - - /* ldmia sp, { r0 - r3, fp, lr } */ - tcg_out32(s, (cond << 28) | 0x089d500f); - - tcg_out_dat_reg(s, cond, ARITH_MOV, 0, 0, args[2], SHIFT_IMM_LSL(0)); - tcg_out_dat_reg(s, cond, ARITH_MOV, 1, 0, args[3], SHIFT_IMM_LSL(0)); - tcg_out_dat_reg(s, cond, ARITH_MOV, 2, 0, args[4], SHIFT_IMM_LSL(0)); - tcg_out_dat_reg(s, cond, ARITH_MOV, 3, 0, 2, shift); - - tcg_out_call(s, cond, (uint32_t) helper_rem); - - tcg_out_dat_reg(s, cond, ARITH_MOV, rem_reg, 0, 0, SHIFT_IMM_LSL(0)); - tcg_out_dat_reg(s, cond, ARITH_MOV, div_reg, 0, 8, SHIFT_IMM_LSL(0)); - - /* ldr r0, [sp], #4 */ - if (rem_reg != 0 && div_reg != 0) - tcg_out32(s, (cond << 28) | 0x04bd0004); - /* ldr r1, [sp], #4 */ - if (rem_reg != 1 && div_reg != 1) - tcg_out32(s, (cond << 28) | 0x04bd1004); - /* ldr r2, [sp], #4 */ - if (rem_reg != 2 && div_reg != 2) - tcg_out32(s, (cond << 28) | 0x04bd2004); - /* ldr r3, [sp], #4 */ - if (rem_reg != 3 && div_reg != 3) - tcg_out32(s, (cond << 28) | 0x04bd3004); - /* ldr ip, [sp], #4 */ - if (rem_reg != 12 && div_reg != 12) - tcg_out32(s, (cond << 28) | 0x04bdc004); - /* ldr lr, [sp], #4 */ - if (rem_reg != 14 && div_reg != 14) - tcg_out32(s, (cond << 28) | 0x04bde004); -} - -#ifdef CONFIG_SOFTMMU - -#include "../../softmmu_defs.h" - -static void *qemu_ld_helpers[4] = { - __ldb_mmu, - __ldw_mmu, - __ldl_mmu, - __ldq_mmu, -}; - -static void *qemu_st_helpers[4] = { - __stb_mmu, - __stw_mmu, - __stl_mmu, - __stq_mmu, -}; -#endif - -#define TLB_SHIFT (CPU_TLB_ENTRY_BITS + CPU_TLB_BITS) - -static inline void tcg_out_qemu_ld(TCGContext *s, int cond, - const TCGArg *args, int opc) -{ - int addr_reg, data_reg, data_reg2; -#ifdef CONFIG_SOFTMMU - int mem_index, s_bits; -# if TARGET_LONG_BITS == 64 - int addr_reg2; -# endif - uint32_t *label_ptr; -#endif - - data_reg = *args++; - if (opc == 3) - data_reg2 = *args++; - else - data_reg2 = 0; /* suppress warning */ - addr_reg = *args++; -#ifdef CONFIG_SOFTMMU -# if TARGET_LONG_BITS == 64 - addr_reg2 = *args++; -# endif - mem_index = *args; - s_bits = opc & 3; - - /* Should generate something like the following: - * shr r8, addr_reg, #TARGET_PAGE_BITS - * and r0, r8, #(CPU_TLB_SIZE - 1) @ Assumption: CPU_TLB_BITS <= 8 - * add r0, env, r0 lsl #CPU_TLB_ENTRY_BITS - */ -# if CPU_TLB_BITS > 8 -# error -# endif - tcg_out_dat_reg(s, COND_AL, ARITH_MOV, - 8, 0, addr_reg, SHIFT_IMM_LSR(TARGET_PAGE_BITS)); - tcg_out_dat_imm(s, COND_AL, ARITH_AND, - 0, 8, CPU_TLB_SIZE - 1); - tcg_out_dat_reg(s, COND_AL, ARITH_ADD, - 0, TCG_AREG0, 0, SHIFT_IMM_LSL(CPU_TLB_ENTRY_BITS)); - /* In the - * ldr r1 [r0, #(offsetof(CPUState, tlb_table[mem_index][0].addr_read))] - * below, the offset is likely to exceed 12 bits if mem_index != 0 and - * not exceed otherwise, so use an - * add r0, r0, #(mem_index * sizeof *CPUState.tlb_table) - * before. - */ - if (mem_index) - tcg_out_dat_imm(s, COND_AL, ARITH_ADD, 0, 0, - (mem_index << (TLB_SHIFT & 1)) | - ((16 - (TLB_SHIFT >> 1)) << 8)); - tcg_out_ld32_12(s, COND_AL, 1, 0, - offsetof(CPUState, tlb_table[0][0].addr_read)); - tcg_out_dat_reg(s, COND_AL, ARITH_CMP, - 0, 1, 8, SHIFT_IMM_LSL(TARGET_PAGE_BITS)); - /* Check alignment. */ - if (s_bits) - tcg_out_dat_imm(s, COND_EQ, ARITH_TST, - 0, addr_reg, (1 << s_bits) - 1); -# if TARGET_LONG_BITS == 64 - /* XXX: possibly we could use a block data load or writeback in - * the first access. */ - tcg_out_ld32_12(s, COND_EQ, 1, 0, - offsetof(CPUState, tlb_table[0][0].addr_read) + 4); - tcg_out_dat_reg(s, COND_EQ, ARITH_CMP, - 0, 1, addr_reg2, SHIFT_IMM_LSL(0)); -# endif - tcg_out_ld32_12(s, COND_EQ, 1, 0, - offsetof(CPUState, tlb_table[0][0].addend)); - - switch (opc) { - case 0: - tcg_out_ld8_r(s, COND_EQ, data_reg, addr_reg, 1); - break; - case 0 | 4: - tcg_out_ld8s_r(s, COND_EQ, data_reg, addr_reg, 1); - break; - case 1: - tcg_out_ld16u_r(s, COND_EQ, data_reg, addr_reg, 1); - break; - case 1 | 4: - tcg_out_ld16s_r(s, COND_EQ, data_reg, addr_reg, 1); - break; - case 2: - default: - tcg_out_ld32_r(s, COND_EQ, data_reg, addr_reg, 1); - break; - case 3: - tcg_out_ld32_rwb(s, COND_EQ, data_reg, 1, addr_reg); - tcg_out_ld32_12(s, COND_EQ, data_reg2, 1, 4); - break; - } - - label_ptr = (void *) s->code_ptr; - tcg_out_b(s, COND_EQ, 8); - -# ifdef SAVE_LR - tcg_out_dat_reg(s, cond, ARITH_MOV, 8, 0, 14, SHIFT_IMM_LSL(0)); -# endif - - /* TODO: move this code to where the constants pool will be */ - if (addr_reg) - tcg_out_dat_reg(s, cond, ARITH_MOV, - 0, 0, addr_reg, SHIFT_IMM_LSL(0)); -# if TARGET_LONG_BITS == 32 - tcg_out_dat_imm(s, cond, ARITH_MOV, 1, 0, mem_index); -# else - if (addr_reg2 != 1) - tcg_out_dat_reg(s, cond, ARITH_MOV, - 1, 0, addr_reg2, SHIFT_IMM_LSL(0)); - tcg_out_dat_imm(s, cond, ARITH_MOV, 2, 0, mem_index); -# endif - tcg_out_bl(s, cond, (tcg_target_long) qemu_ld_helpers[s_bits] - - (tcg_target_long) s->code_ptr); - - switch (opc) { - case 0 | 4: - tcg_out_dat_reg(s, cond, ARITH_MOV, - 0, 0, 0, SHIFT_IMM_LSL(24)); - tcg_out_dat_reg(s, cond, ARITH_MOV, - data_reg, 0, 0, SHIFT_IMM_ASR(24)); - break; - case 1 | 4: - tcg_out_dat_reg(s, cond, ARITH_MOV, - 0, 0, 0, SHIFT_IMM_LSL(16)); - tcg_out_dat_reg(s, cond, ARITH_MOV, - data_reg, 0, 0, SHIFT_IMM_ASR(16)); - break; - case 0: - case 1: - case 2: - default: - if (data_reg) - tcg_out_dat_reg(s, cond, ARITH_MOV, - data_reg, 0, 0, SHIFT_IMM_LSL(0)); - break; - case 3: - if (data_reg != 0) - tcg_out_dat_reg(s, cond, ARITH_MOV, - data_reg, 0, 0, SHIFT_IMM_LSL(0)); - if (data_reg2 != 1) - tcg_out_dat_reg(s, cond, ARITH_MOV, - data_reg2, 0, 1, SHIFT_IMM_LSL(0)); - break; - } - -# ifdef SAVE_LR - tcg_out_dat_reg(s, cond, ARITH_MOV, 14, 0, 8, SHIFT_IMM_LSL(0)); -# endif - - *label_ptr += ((void *) s->code_ptr - (void *) label_ptr - 8) >> 2; -#else /* !CONFIG_SOFTMMU */ - if (GUEST_BASE) { - uint32_t offset = GUEST_BASE; - int i; - int rot; - - while (offset) { - i = ctz32(offset) & ~1; - rot = ((32 - i) << 7) & 0xf00; - - tcg_out_dat_imm(s, COND_AL, ARITH_ADD, 8, addr_reg, - ((offset >> i) & 0xff) | rot); - addr_reg = 8; - offset &= ~(0xff << i); - } - } - switch (opc) { - case 0: - tcg_out_ld8_12(s, COND_AL, data_reg, addr_reg, 0); - break; - case 0 | 4: - tcg_out_ld8s_8(s, COND_AL, data_reg, addr_reg, 0); - break; - case 1: - tcg_out_ld16u_8(s, COND_AL, data_reg, addr_reg, 0); - break; - case 1 | 4: - tcg_out_ld16s_8(s, COND_AL, data_reg, addr_reg, 0); - break; - case 2: - default: - tcg_out_ld32_12(s, COND_AL, data_reg, addr_reg, 0); - break; - case 3: - /* TODO: use block load - - * check that data_reg2 > data_reg or the other way */ - if (data_reg == addr_reg) { - tcg_out_ld32_12(s, COND_AL, data_reg2, addr_reg, 4); - tcg_out_ld32_12(s, COND_AL, data_reg, addr_reg, 0); - } else { - tcg_out_ld32_12(s, COND_AL, data_reg, addr_reg, 0); - tcg_out_ld32_12(s, COND_AL, data_reg2, addr_reg, 4); - } - break; - } -#endif -} - -static inline void tcg_out_qemu_st(TCGContext *s, int cond, - const TCGArg *args, int opc) -{ - int addr_reg, data_reg, data_reg2; -#ifdef CONFIG_SOFTMMU - int mem_index, s_bits; -# if TARGET_LONG_BITS == 64 - int addr_reg2; -# endif - uint32_t *label_ptr; -#endif - - data_reg = *args++; - if (opc == 3) - data_reg2 = *args++; - else - data_reg2 = 0; /* suppress warning */ - addr_reg = *args++; -#ifdef CONFIG_SOFTMMU -# if TARGET_LONG_BITS == 64 - addr_reg2 = *args++; -# endif - mem_index = *args; - s_bits = opc & 3; - - /* Should generate something like the following: - * shr r8, addr_reg, #TARGET_PAGE_BITS - * and r0, r8, #(CPU_TLB_SIZE - 1) @ Assumption: CPU_TLB_BITS <= 8 - * add r0, env, r0 lsl #CPU_TLB_ENTRY_BITS - */ - tcg_out_dat_reg(s, COND_AL, ARITH_MOV, - 8, 0, addr_reg, SHIFT_IMM_LSR(TARGET_PAGE_BITS)); - tcg_out_dat_imm(s, COND_AL, ARITH_AND, - 0, 8, CPU_TLB_SIZE - 1); - tcg_out_dat_reg(s, COND_AL, ARITH_ADD, - 0, TCG_AREG0, 0, SHIFT_IMM_LSL(CPU_TLB_ENTRY_BITS)); - /* In the - * ldr r1 [r0, #(offsetof(CPUState, tlb_table[mem_index][0].addr_write))] - * below, the offset is likely to exceed 12 bits if mem_index != 0 and - * not exceed otherwise, so use an - * add r0, r0, #(mem_index * sizeof *CPUState.tlb_table) - * before. - */ - if (mem_index) - tcg_out_dat_imm(s, COND_AL, ARITH_ADD, 0, 0, - (mem_index << (TLB_SHIFT & 1)) | - ((16 - (TLB_SHIFT >> 1)) << 8)); - tcg_out_ld32_12(s, COND_AL, 1, 0, - offsetof(CPUState, tlb_table[0][0].addr_write)); - tcg_out_dat_reg(s, COND_AL, ARITH_CMP, - 0, 1, 8, SHIFT_IMM_LSL(TARGET_PAGE_BITS)); - /* Check alignment. */ - if (s_bits) - tcg_out_dat_imm(s, COND_EQ, ARITH_TST, - 0, addr_reg, (1 << s_bits) - 1); -# if TARGET_LONG_BITS == 64 - /* XXX: possibly we could use a block data load or writeback in - * the first access. */ - tcg_out_ld32_12(s, COND_EQ, 1, 0, - offsetof(CPUState, tlb_table[0][0].addr_write) - + 4); - tcg_out_dat_reg(s, COND_EQ, ARITH_CMP, - 0, 1, addr_reg2, SHIFT_IMM_LSL(0)); -# endif - tcg_out_ld32_12(s, COND_EQ, 1, 0, - offsetof(CPUState, tlb_table[0][0].addend)); - - switch (opc) { - case 0: - tcg_out_st8_r(s, COND_EQ, data_reg, addr_reg, 1); - break; - case 0 | 4: - tcg_out_st8s_r(s, COND_EQ, data_reg, addr_reg, 1); - break; - case 1: - tcg_out_st16u_r(s, COND_EQ, data_reg, addr_reg, 1); - break; - case 1 | 4: - tcg_out_st16s_r(s, COND_EQ, data_reg, addr_reg, 1); - break; - case 2: - default: - tcg_out_st32_r(s, COND_EQ, data_reg, addr_reg, 1); - break; - case 3: - tcg_out_st32_rwb(s, COND_EQ, data_reg, 1, addr_reg); - tcg_out_st32_12(s, COND_EQ, data_reg2, 1, 4); - break; - } - - label_ptr = (void *) s->code_ptr; - tcg_out_b(s, COND_EQ, 8); - - /* TODO: move this code to where the constants pool will be */ - if (addr_reg) - tcg_out_dat_reg(s, cond, ARITH_MOV, - 0, 0, addr_reg, SHIFT_IMM_LSL(0)); -# if TARGET_LONG_BITS == 32 - switch (opc) { - case 0: - tcg_out_dat_imm(s, cond, ARITH_AND, 1, data_reg, 0xff); - tcg_out_dat_imm(s, cond, ARITH_MOV, 2, 0, mem_index); - break; - case 1: - tcg_out_dat_reg(s, cond, ARITH_MOV, - 1, 0, data_reg, SHIFT_IMM_LSL(16)); - tcg_out_dat_reg(s, cond, ARITH_MOV, - 1, 0, 1, SHIFT_IMM_LSR(16)); - tcg_out_dat_imm(s, cond, ARITH_MOV, 2, 0, mem_index); - break; - case 2: - if (data_reg != 1) - tcg_out_dat_reg(s, cond, ARITH_MOV, - 1, 0, data_reg, SHIFT_IMM_LSL(0)); - tcg_out_dat_imm(s, cond, ARITH_MOV, 2, 0, mem_index); - break; - case 3: - if (data_reg != 1) - tcg_out_dat_reg(s, cond, ARITH_MOV, - 1, 0, data_reg, SHIFT_IMM_LSL(0)); - if (data_reg2 != 2) - tcg_out_dat_reg(s, cond, ARITH_MOV, - 2, 0, data_reg2, SHIFT_IMM_LSL(0)); - tcg_out_dat_imm(s, cond, ARITH_MOV, 3, 0, mem_index); - break; - } -# else - if (addr_reg2 != 1) - tcg_out_dat_reg(s, cond, ARITH_MOV, - 1, 0, addr_reg2, SHIFT_IMM_LSL(0)); - switch (opc) { - case 0: - tcg_out_dat_imm(s, cond, ARITH_AND, 2, data_reg, 0xff); - tcg_out_dat_imm(s, cond, ARITH_MOV, 3, 0, mem_index); - break; - case 1: - tcg_out_dat_reg(s, cond, ARITH_MOV, - 2, 0, data_reg, SHIFT_IMM_LSL(16)); - tcg_out_dat_reg(s, cond, ARITH_MOV, - 2, 0, 2, SHIFT_IMM_LSR(16)); - tcg_out_dat_imm(s, cond, ARITH_MOV, 3, 0, mem_index); - break; - case 2: - if (data_reg != 2) - tcg_out_dat_reg(s, cond, ARITH_MOV, - 2, 0, data_reg, SHIFT_IMM_LSL(0)); - tcg_out_dat_imm(s, cond, ARITH_MOV, 3, 0, mem_index); - break; - case 3: - tcg_out_dat_imm(s, cond, ARITH_MOV, 8, 0, mem_index); - tcg_out32(s, (cond << 28) | 0x052d8010); /* str r8, [sp, #-0x10]! */ - if (data_reg != 2) - tcg_out_dat_reg(s, cond, ARITH_MOV, - 2, 0, data_reg, SHIFT_IMM_LSL(0)); - if (data_reg2 != 3) - tcg_out_dat_reg(s, cond, ARITH_MOV, - 3, 0, data_reg2, SHIFT_IMM_LSL(0)); - break; - } -# endif - -# ifdef SAVE_LR - tcg_out_dat_reg(s, cond, ARITH_MOV, 8, 0, 14, SHIFT_IMM_LSL(0)); -# endif - - tcg_out_bl(s, cond, (tcg_target_long) qemu_st_helpers[s_bits] - - (tcg_target_long) s->code_ptr); -# if TARGET_LONG_BITS == 64 - if (opc == 3) - tcg_out_dat_imm(s, cond, ARITH_ADD, 13, 13, 0x10); -# endif - -# ifdef SAVE_LR - tcg_out_dat_reg(s, cond, ARITH_MOV, 14, 0, 8, SHIFT_IMM_LSL(0)); -# endif - - *label_ptr += ((void *) s->code_ptr - (void *) label_ptr - 8) >> 2; -#else /* !CONFIG_SOFTMMU */ - if (GUEST_BASE) { - uint32_t offset = GUEST_BASE; - int i; - int rot; - - while (offset) { - i = ctz32(offset) & ~1; - rot = ((32 - i) << 7) & 0xf00; - - tcg_out_dat_imm(s, COND_AL, ARITH_ADD, 8, addr_reg, - ((offset >> i) & 0xff) | rot); - addr_reg = 8; - offset &= ~(0xff << i); - } - } - switch (opc) { - case 0: - tcg_out_st8_12(s, COND_AL, data_reg, addr_reg, 0); - break; - case 0 | 4: - tcg_out_st8s_8(s, COND_AL, data_reg, addr_reg, 0); - break; - case 1: - tcg_out_st16u_8(s, COND_AL, data_reg, addr_reg, 0); - break; - case 1 | 4: - tcg_out_st16s_8(s, COND_AL, data_reg, addr_reg, 0); - break; - case 2: - default: - tcg_out_st32_12(s, COND_AL, data_reg, addr_reg, 0); - break; - case 3: - /* TODO: use block store - - * check that data_reg2 > data_reg or the other way */ - tcg_out_st32_12(s, COND_AL, data_reg, addr_reg, 0); - tcg_out_st32_12(s, COND_AL, data_reg2, addr_reg, 4); - break; - } -#endif -} - -static uint8_t *tb_ret_addr; - -static inline void tcg_out_op(TCGContext *s, int opc, - const TCGArg *args, const int *const_args) -{ - int c; - - switch (opc) { - case INDEX_op_exit_tb: -#ifdef SAVE_LR - if (args[0] >> 8) - tcg_out_ld32_12(s, COND_AL, TCG_REG_R0, 15, 0); - else - tcg_out_dat_imm(s, COND_AL, ARITH_MOV, TCG_REG_R0, 0, args[0]); - tcg_out_dat_reg(s, COND_AL, ARITH_MOV, 15, 0, 14, SHIFT_IMM_LSL(0)); - if (args[0] >> 8) - tcg_out32(s, args[0]); -#else - { - uint8_t *ld_ptr = s->code_ptr; - if (args[0] >> 8) - tcg_out_ld32_12(s, COND_AL, 0, 15, 0); - else - tcg_out_dat_imm(s, COND_AL, ARITH_MOV, 0, 0, args[0]); - tcg_out_goto(s, COND_AL, (tcg_target_ulong) tb_ret_addr); - if (args[0] >> 8) { - *ld_ptr = (uint8_t) (s->code_ptr - ld_ptr) - 8; - tcg_out32(s, args[0]); - } - } -#endif - break; - case INDEX_op_goto_tb: - if (s->tb_jmp_offset) { - /* Direct jump method */ -#if defined(USE_DIRECT_JUMP) - s->tb_jmp_offset[args[0]] = s->code_ptr - s->code_buf; - tcg_out_b(s, COND_AL, 8); -#else - tcg_out_ld32_12(s, COND_AL, 15, 15, -4); - s->tb_jmp_offset[args[0]] = s->code_ptr - s->code_buf; - tcg_out32(s, 0); -#endif - } else { - /* Indirect jump method */ -#if 1 - c = (int) (s->tb_next + args[0]) - ((int) s->code_ptr + 8); - if (c > 0xfff || c < -0xfff) { - tcg_out_movi32(s, COND_AL, TCG_REG_R0, - (tcg_target_long) (s->tb_next + args[0])); - tcg_out_ld32_12(s, COND_AL, 15, TCG_REG_R0, 0); - } else - tcg_out_ld32_12(s, COND_AL, 15, 15, c); -#else - tcg_out_ld32_12(s, COND_AL, TCG_REG_R0, 15, 0); - tcg_out_ld32_12(s, COND_AL, 15, TCG_REG_R0, 0); - tcg_out32(s, (tcg_target_long) (s->tb_next + args[0])); -#endif - } - s->tb_next_offset[args[0]] = s->code_ptr - s->code_buf; - break; - case INDEX_op_call: - if (const_args[0]) - tcg_out_call(s, COND_AL, args[0]); - else - tcg_out_callr(s, COND_AL, args[0]); - break; - case INDEX_op_jmp: - if (const_args[0]) - tcg_out_goto(s, COND_AL, args[0]); - else - tcg_out_bx(s, COND_AL, args[0]); - break; - case INDEX_op_br: - tcg_out_goto_label(s, COND_AL, args[0]); - break; - - case INDEX_op_ld8u_i32: - tcg_out_ld8u(s, COND_AL, args[0], args[1], args[2]); - break; - case INDEX_op_ld8s_i32: - tcg_out_ld8s(s, COND_AL, args[0], args[1], args[2]); - break; - case INDEX_op_ld16u_i32: - tcg_out_ld16u(s, COND_AL, args[0], args[1], args[2]); - break; - case INDEX_op_ld16s_i32: - tcg_out_ld16s(s, COND_AL, args[0], args[1], args[2]); - break; - case INDEX_op_ld_i32: - tcg_out_ld32u(s, COND_AL, args[0], args[1], args[2]); - break; - case INDEX_op_st8_i32: - tcg_out_st8u(s, COND_AL, args[0], args[1], args[2]); - break; - case INDEX_op_st16_i32: - tcg_out_st16u(s, COND_AL, args[0], args[1], args[2]); - break; - case INDEX_op_st_i32: - tcg_out_st32(s, COND_AL, args[0], args[1], args[2]); - break; - - case INDEX_op_mov_i32: - tcg_out_dat_reg(s, COND_AL, ARITH_MOV, - args[0], 0, args[1], SHIFT_IMM_LSL(0)); - break; - case INDEX_op_movi_i32: - tcg_out_movi32(s, COND_AL, args[0], args[1]); - break; - case INDEX_op_add_i32: - c = ARITH_ADD; - goto gen_arith; - case INDEX_op_sub_i32: - c = ARITH_SUB; - goto gen_arith; - case INDEX_op_and_i32: - c = ARITH_AND; - goto gen_arith; - case INDEX_op_or_i32: - c = ARITH_ORR; - goto gen_arith; - case INDEX_op_xor_i32: - c = ARITH_EOR; - /* Fall through. */ - gen_arith: - if (const_args[2]) { - int rot; - rot = encode_imm(args[2]); - tcg_out_dat_imm(s, COND_AL, c, - args[0], args[1], rotl(args[2], rot) | (rot << 7)); - } else - tcg_out_dat_reg(s, COND_AL, c, - args[0], args[1], args[2], SHIFT_IMM_LSL(0)); - break; - case INDEX_op_add2_i32: - tcg_out_dat_reg2(s, COND_AL, ARITH_ADD, ARITH_ADC, - args[0], args[1], args[2], args[3], - args[4], args[5], SHIFT_IMM_LSL(0)); - break; - case INDEX_op_sub2_i32: - tcg_out_dat_reg2(s, COND_AL, ARITH_SUB, ARITH_SBC, - args[0], args[1], args[2], args[3], - args[4], args[5], SHIFT_IMM_LSL(0)); - break; - case INDEX_op_neg_i32: - tcg_out_dat_imm(s, COND_AL, ARITH_RSB, args[0], args[1], 0); - break; - case INDEX_op_not_i32: - tcg_out_dat_reg(s, COND_AL, - ARITH_MVN, args[0], 0, args[1], SHIFT_IMM_LSL(0)); - break; - case INDEX_op_mul_i32: - tcg_out_mul32(s, COND_AL, args[0], args[1], args[2]); - break; - case INDEX_op_mulu2_i32: - tcg_out_umull32(s, COND_AL, args[0], args[1], args[2], args[3]); - break; - case INDEX_op_div2_i32: - tcg_out_div_helper(s, COND_AL, args, - tcg_helper_div_i64, tcg_helper_rem_i64, - SHIFT_IMM_ASR(31)); - break; - case INDEX_op_divu2_i32: - tcg_out_div_helper(s, COND_AL, args, - tcg_helper_divu_i64, tcg_helper_remu_i64, - SHIFT_IMM_LSR(31)); - break; - /* XXX: Perhaps args[2] & 0x1f is wrong */ - case INDEX_op_shl_i32: - c = const_args[2] ? - SHIFT_IMM_LSL(args[2] & 0x1f) : SHIFT_REG_LSL(args[2]); - goto gen_shift32; - case INDEX_op_shr_i32: - c = const_args[2] ? (args[2] & 0x1f) ? SHIFT_IMM_LSR(args[2] & 0x1f) : - SHIFT_IMM_LSL(0) : SHIFT_REG_LSR(args[2]); - goto gen_shift32; - case INDEX_op_sar_i32: - c = const_args[2] ? (args[2] & 0x1f) ? SHIFT_IMM_ASR(args[2] & 0x1f) : - SHIFT_IMM_LSL(0) : SHIFT_REG_ASR(args[2]); - /* Fall through. */ - gen_shift32: - tcg_out_dat_reg(s, COND_AL, ARITH_MOV, args[0], 0, args[1], c); - break; - - case INDEX_op_brcond_i32: - tcg_out_dat_reg(s, COND_AL, ARITH_CMP, 0, - args[0], args[1], SHIFT_IMM_LSL(0)); - tcg_out_goto_label(s, tcg_cond_to_arm_cond[args[2]], args[3]); - break; - case INDEX_op_brcond2_i32: - /* The resulting conditions are: - * TCG_COND_EQ --> a0 == a2 && a1 == a3, - * TCG_COND_NE --> (a0 != a2 && a1 == a3) || a1 != a3, - * TCG_COND_LT(U) --> (a0 < a2 && a1 == a3) || a1 < a3, - * TCG_COND_GE(U) --> (a0 >= a2 && a1 == a3) || (a1 >= a3 && a1 != a3), - * TCG_COND_LE(U) --> (a0 <= a2 && a1 == a3) || (a1 <= a3 && a1 != a3), - * TCG_COND_GT(U) --> (a0 > a2 && a1 == a3) || a1 > a3, - */ - tcg_out_dat_reg(s, COND_AL, ARITH_CMP, 0, - args[1], args[3], SHIFT_IMM_LSL(0)); - tcg_out_dat_reg(s, COND_EQ, ARITH_CMP, 0, - args[0], args[2], SHIFT_IMM_LSL(0)); - tcg_out_goto_label(s, tcg_cond_to_arm_cond[args[4]], args[5]); - break; - - case INDEX_op_qemu_ld8u: - tcg_out_qemu_ld(s, COND_AL, args, 0); - break; - case INDEX_op_qemu_ld8s: - tcg_out_qemu_ld(s, COND_AL, args, 0 | 4); - break; - case INDEX_op_qemu_ld16u: - tcg_out_qemu_ld(s, COND_AL, args, 1); - break; - case INDEX_op_qemu_ld16s: - tcg_out_qemu_ld(s, COND_AL, args, 1 | 4); - break; - case INDEX_op_qemu_ld32u: - tcg_out_qemu_ld(s, COND_AL, args, 2); - break; - case INDEX_op_qemu_ld64: - tcg_out_qemu_ld(s, COND_AL, args, 3); - break; - - case INDEX_op_qemu_st8: - tcg_out_qemu_st(s, COND_AL, args, 0); - break; - case INDEX_op_qemu_st16: - tcg_out_qemu_st(s, COND_AL, args, 1); - break; - case INDEX_op_qemu_st32: - tcg_out_qemu_st(s, COND_AL, args, 2); - break; - case INDEX_op_qemu_st64: - tcg_out_qemu_st(s, COND_AL, args, 3); - break; - - case INDEX_op_ext8s_i32: -#ifdef __ARM_ARCH_7A__ - /* sxtb */ - tcg_out32(s, 0xe6af0070 | (args[0] << 12) | args[1]); -#else - tcg_out_dat_reg(s, COND_AL, ARITH_MOV, - args[0], 0, args[1], SHIFT_IMM_LSL(24)); - tcg_out_dat_reg(s, COND_AL, ARITH_MOV, - args[0], 0, args[0], SHIFT_IMM_ASR(24)); -#endif - break; - case INDEX_op_ext16s_i32: -#ifdef __ARM_ARCH_7A__ - /* sxth */ - tcg_out32(s, 0xe6bf0070 | (args[0] << 12) | args[1]); -#else - tcg_out_dat_reg(s, COND_AL, ARITH_MOV, - args[0], 0, args[1], SHIFT_IMM_LSL(16)); - tcg_out_dat_reg(s, COND_AL, ARITH_MOV, - args[0], 0, args[0], SHIFT_IMM_ASR(16)); -#endif - break; - - default: - tcg_abort(); - } -} - -static const TCGTargetOpDef arm_op_defs[] = { - { INDEX_op_exit_tb, { } }, - { INDEX_op_goto_tb, { } }, - { INDEX_op_call, { "ri" } }, - { INDEX_op_jmp, { "ri" } }, - { INDEX_op_br, { } }, - - { INDEX_op_mov_i32, { "r", "r" } }, - { INDEX_op_movi_i32, { "r" } }, - - { INDEX_op_ld8u_i32, { "r", "r" } }, - { INDEX_op_ld8s_i32, { "r", "r" } }, - { INDEX_op_ld16u_i32, { "r", "r" } }, - { INDEX_op_ld16s_i32, { "r", "r" } }, - { INDEX_op_ld_i32, { "r", "r" } }, - { INDEX_op_st8_i32, { "r", "r" } }, - { INDEX_op_st16_i32, { "r", "r" } }, - { INDEX_op_st_i32, { "r", "r" } }, - - /* TODO: "r", "r", "ri" */ - { INDEX_op_add_i32, { "r", "r", "rI" } }, - { INDEX_op_sub_i32, { "r", "r", "rI" } }, - { INDEX_op_mul_i32, { "r", "r", "r" } }, - { INDEX_op_mulu2_i32, { "r", "r", "r", "r" } }, - { INDEX_op_div2_i32, { "r", "r", "r", "1", "2" } }, - { INDEX_op_divu2_i32, { "r", "r", "r", "1", "2" } }, - { INDEX_op_and_i32, { "r", "r", "rI" } }, - { INDEX_op_or_i32, { "r", "r", "rI" } }, - { INDEX_op_xor_i32, { "r", "r", "rI" } }, - { INDEX_op_neg_i32, { "r", "r" } }, - { INDEX_op_not_i32, { "r", "r" } }, - - { INDEX_op_shl_i32, { "r", "r", "ri" } }, - { INDEX_op_shr_i32, { "r", "r", "ri" } }, - { INDEX_op_sar_i32, { "r", "r", "ri" } }, - - { INDEX_op_brcond_i32, { "r", "r" } }, - - /* TODO: "r", "r", "r", "r", "ri", "ri" */ - { INDEX_op_add2_i32, { "r", "r", "r", "r", "r", "r" } }, - { INDEX_op_sub2_i32, { "r", "r", "r", "r", "r", "r" } }, - { INDEX_op_brcond2_i32, { "r", "r", "r", "r" } }, - - { INDEX_op_qemu_ld8u, { "r", "x", "X" } }, - { INDEX_op_qemu_ld8s, { "r", "x", "X" } }, - { INDEX_op_qemu_ld16u, { "r", "x", "X" } }, - { INDEX_op_qemu_ld16s, { "r", "x", "X" } }, - { INDEX_op_qemu_ld32u, { "r", "x", "X" } }, - { INDEX_op_qemu_ld64, { "d", "r", "x", "X" } }, - - { INDEX_op_qemu_st8, { "x", "x", "X" } }, - { INDEX_op_qemu_st16, { "x", "x", "X" } }, - { INDEX_op_qemu_st32, { "x", "x", "X" } }, - { INDEX_op_qemu_st64, { "x", "D", "x", "X" } }, - - { INDEX_op_ext8s_i32, { "r", "r" } }, - { INDEX_op_ext16s_i32, { "r", "r" } }, - - { -1 }, -}; - -void tcg_target_init(TCGContext *s) -{ - /* fail safe */ - if ((1 << CPU_TLB_ENTRY_BITS) != sizeof(CPUTLBEntry)) - tcg_abort(); - - tcg_regset_set32(tcg_target_available_regs[TCG_TYPE_I32], 0, - ((2 << TCG_REG_R14) - 1) & ~(1 << TCG_REG_R8)); - tcg_regset_set32(tcg_target_call_clobber_regs, 0, - ((2 << TCG_REG_R3) - 1) | - (1 << TCG_REG_R12) | (1 << TCG_REG_R14)); - - tcg_regset_clear(s->reserved_regs); -#ifdef SAVE_LR - tcg_regset_set_reg(s->reserved_regs, TCG_REG_R14); -#endif - tcg_regset_set_reg(s->reserved_regs, TCG_REG_CALL_STACK); - tcg_regset_set_reg(s->reserved_regs, TCG_REG_R8); - - tcg_add_target_add_op_defs(arm_op_defs); -} - -static inline void tcg_out_ld(TCGContext *s, TCGType type, int arg, - int arg1, tcg_target_long arg2) -{ - tcg_out_ld32u(s, COND_AL, arg, arg1, arg2); -} - -static inline void tcg_out_st(TCGContext *s, TCGType type, int arg, - int arg1, tcg_target_long arg2) -{ - tcg_out_st32(s, COND_AL, arg, arg1, arg2); -} - -static void tcg_out_addi(TCGContext *s, int reg, tcg_target_long val) -{ - if (val > 0) - if (val < 0x100) - tcg_out_dat_imm(s, COND_AL, ARITH_ADD, reg, reg, val); - else - tcg_abort(); - else if (val < 0) { - if (val > -0x100) - tcg_out_dat_imm(s, COND_AL, ARITH_SUB, reg, reg, -val); - else - tcg_abort(); - } -} - -static inline void tcg_out_mov(TCGContext *s, int ret, int arg) -{ - tcg_out_dat_reg(s, COND_AL, ARITH_MOV, ret, 0, arg, SHIFT_IMM_LSL(0)); -} - -static inline void tcg_out_movi(TCGContext *s, TCGType type, - int ret, tcg_target_long arg) -{ - tcg_out_movi32(s, COND_AL, ret, arg); -} - -void tcg_target_qemu_prologue(TCGContext *s) -{ - /* stmdb sp!, { r9 - r11, lr } */ - tcg_out32(s, (COND_AL << 28) | 0x092d4e00); - - tcg_out_bx(s, COND_AL, TCG_REG_R0); - tb_ret_addr = s->code_ptr; - - /* ldmia sp!, { r9 - r11, pc } */ - tcg_out32(s, (COND_AL << 28) | 0x08bd8e00); -} diff --git a/qemu/qemu-git/tcg/arm/.svn/text-base/tcg-target.h.svn-base b/qemu/qemu-git/tcg/arm/.svn/text-base/tcg-target.h.svn-base deleted file mode 100644 index 71e1ec5..0000000 --- a/qemu/qemu-git/tcg/arm/.svn/text-base/tcg-target.h.svn-base +++ /dev/null @@ -1,85 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2008 Fabrice Bellard - * Copyright (c) 2008 Andrzej Zaborowski - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ -#define TCG_TARGET_ARM 1 - -#define TCG_TARGET_REG_BITS 32 -#undef TCG_TARGET_WORDS_BIGENDIAN -#undef TCG_TARGET_HAS_div_i32 -#undef TCG_TARGET_HAS_div_i64 -#undef TCG_TARGET_HAS_bswap32_i32 -#define TCG_TARGET_HAS_ext8s_i32 -#define TCG_TARGET_HAS_ext16s_i32 -#define TCG_TARGET_HAS_neg_i32 -#undef TCG_TARGET_HAS_neg_i64 -#define TCG_TARGET_HAS_not_i32 -#undef TCG_TARGET_STACK_GROWSUP - -enum { - TCG_REG_R0 = 0, - TCG_REG_R1, - TCG_REG_R2, - TCG_REG_R3, - TCG_REG_R4, - TCG_REG_R5, - TCG_REG_R6, - TCG_REG_R7, - TCG_REG_R8, - TCG_REG_R9, - TCG_REG_R10, - TCG_REG_R11, - TCG_REG_R12, - TCG_REG_R13, - TCG_REG_R14, -}; - -#define TCG_TARGET_NB_REGS 15 - -#define TCG_CT_CONST_ARM 0x100 - -/* used for function call generation */ -#define TCG_REG_CALL_STACK TCG_REG_R13 -#define TCG_TARGET_STACK_ALIGN 8 -#define TCG_TARGET_CALL_STACK_OFFSET 0 - -#define TCG_TARGET_HAS_GUEST_BASE - -enum { - /* Note: must be synced with dyngen-exec.h */ - TCG_AREG0 = TCG_REG_R7, - TCG_AREG1 = TCG_REG_R4, - TCG_AREG2 = TCG_REG_R5, -}; - -static inline void flush_icache_range(unsigned long start, unsigned long stop) -{ -#if QEMU_GNUC_PREREQ(4, 1) - __builtin___clear_cache((char *) start, (char *) stop); -#else - register unsigned long _beg __asm ("a1") = start; - register unsigned long _end __asm ("a2") = stop; - register unsigned long _flg __asm ("a3") = 0; - __asm __volatile__ ("swi 0x9f0002" : : "r" (_beg), "r" (_end), "r" (_flg)); -#endif -} diff --git a/qemu/qemu-git/tcg/hppa/.svn/all-wcprops b/qemu/qemu-git/tcg/hppa/.svn/all-wcprops deleted file mode 100644 index 5273562..0000000 --- a/qemu/qemu-git/tcg/hppa/.svn/all-wcprops +++ /dev/null @@ -1,17 +0,0 @@ -K 25 -svn:wc:ra_dav:version-url -V 48 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/hppa -END -tcg-target.c -K 25 -svn:wc:ra_dav:version-url -V 61 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/hppa/tcg-target.c -END -tcg-target.h -K 25 -svn:wc:ra_dav:version-url -V 61 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/hppa/tcg-target.h -END diff --git a/qemu/qemu-git/tcg/hppa/.svn/entries b/qemu/qemu-git/tcg/hppa/.svn/entries deleted file mode 100644 index f6255b0..0000000 --- a/qemu/qemu-git/tcg/hppa/.svn/entries +++ /dev/null @@ -1,96 +0,0 @@ -10 - -dir -11 -http://svn.code.sf.net/p/x49gp/code/qemu/qemu-git/tcg/hppa -http://svn.code.sf.net/p/x49gp/code - - - -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - -481df3bd-3408-496c-b7de-451e46197bb5 - -tcg-target.c -file - - - - -2013-08-23T00:54:47.000000Z -3648cf4b85c8da40b9d2ae3c8a3f86ee -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -29464 - -tcg-target.h -file - - - - -2013-08-23T00:54:47.000000Z -7094eee931532fab56eb908158df4484 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -5645 - diff --git a/qemu/qemu-git/tcg/hppa/.svn/text-base/tcg-target.c.svn-base b/qemu/qemu-git/tcg/hppa/.svn/text-base/tcg-target.c.svn-base deleted file mode 100644 index ddce60c..0000000 --- a/qemu/qemu-git/tcg/hppa/.svn/text-base/tcg-target.c.svn-base +++ /dev/null @@ -1,975 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2008 Fabrice Bellard - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ - -#ifndef NDEBUG -static const char * const tcg_target_reg_names[TCG_TARGET_NB_REGS] = { - "%r0", - "%r1", - "%rp", - "%r3", - "%r4", - "%r5", - "%r6", - "%r7", - "%r8", - "%r9", - "%r10", - "%r11", - "%r12", - "%r13", - "%r14", - "%r15", - "%r16", - "%r17", - "%r18", - "%r19", - "%r20", - "%r21", - "%r22", - "%r23", - "%r24", - "%r25", - "%r26", - "%dp", - "%ret0", - "%ret1", - "%sp", - "%r31", -}; -#endif - -static const int tcg_target_reg_alloc_order[] = { - TCG_REG_R4, - TCG_REG_R5, - TCG_REG_R6, - TCG_REG_R7, - TCG_REG_R8, - TCG_REG_R9, - TCG_REG_R10, - TCG_REG_R11, - TCG_REG_R12, - TCG_REG_R13, - - TCG_REG_R17, - TCG_REG_R14, - TCG_REG_R15, - TCG_REG_R16, -}; - -static const int tcg_target_call_iarg_regs[4] = { - TCG_REG_R26, - TCG_REG_R25, - TCG_REG_R24, - TCG_REG_R23, -}; - -static const int tcg_target_call_oarg_regs[2] = { - TCG_REG_RET0, - TCG_REG_RET1, -}; - -static void patch_reloc(uint8_t *code_ptr, int type, - tcg_target_long value, tcg_target_long addend) -{ - switch (type) { - case R_PARISC_PCREL17F: - hppa_patch17f((uint32_t *)code_ptr, value, addend); - break; - default: - tcg_abort(); - } -} - -/* maximum number of register used for input function arguments */ -static inline int tcg_target_get_call_iarg_regs_count(int flags) -{ - return 4; -} - -/* parse target specific constraints */ -static int target_parse_constraint(TCGArgConstraint *ct, const char **pct_str) -{ - const char *ct_str; - - ct_str = *pct_str; - switch (ct_str[0]) { - case 'r': - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, 0xffffffff); - break; - case 'L': /* qemu_ld/st constraint */ - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, 0xffffffff); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R26); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R25); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R24); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R23); - break; - default: - return -1; - } - ct_str++; - *pct_str = ct_str; - return 0; -} - -/* test if a constant matches the constraint */ -static inline int tcg_target_const_match(tcg_target_long val, - const TCGArgConstraint *arg_ct) -{ - int ct; - - ct = arg_ct->ct; - - /* TODO */ - - return 0; -} - -#define INSN_OP(x) ((x) << 26) -#define INSN_EXT3BR(x) ((x) << 13) -#define INSN_EXT3SH(x) ((x) << 10) -#define INSN_EXT4(x) ((x) << 6) -#define INSN_EXT5(x) (x) -#define INSN_EXT6(x) ((x) << 6) -#define INSN_EXT7(x) ((x) << 6) -#define INSN_EXT8A(x) ((x) << 6) -#define INSN_EXT8B(x) ((x) << 5) -#define INSN_T(x) (x) -#define INSN_R1(x) ((x) << 16) -#define INSN_R2(x) ((x) << 21) -#define INSN_DEP_LEN(x) (32 - (x)) -#define INSN_SHDEP_CP(x) ((31 - (x)) << 5) -#define INSN_SHDEP_P(x) ((x) << 5) -#define INSN_COND(x) ((x) << 13) - -#define COND_NEVER 0 -#define COND_EQUAL 1 -#define COND_LT 2 -#define COND_LTEQ 3 -#define COND_LTU 4 -#define COND_LTUEQ 5 -#define COND_SV 6 -#define COND_OD 7 - - -/* Logical ADD */ -#define ARITH_ADD (INSN_OP(0x02) | INSN_EXT6(0x28)) -#define ARITH_AND (INSN_OP(0x02) | INSN_EXT6(0x08)) -#define ARITH_OR (INSN_OP(0x02) | INSN_EXT6(0x09)) -#define ARITH_XOR (INSN_OP(0x02) | INSN_EXT6(0x0a)) -#define ARITH_SUB (INSN_OP(0x02) | INSN_EXT6(0x10)) - -#define SHD (INSN_OP(0x34) | INSN_EXT3SH(2)) -#define VSHD (INSN_OP(0x34) | INSN_EXT3SH(0)) -#define DEP (INSN_OP(0x35) | INSN_EXT3SH(3)) -#define ZDEP (INSN_OP(0x35) | INSN_EXT3SH(2)) -#define ZVDEP (INSN_OP(0x35) | INSN_EXT3SH(0)) -#define EXTRU (INSN_OP(0x34) | INSN_EXT3SH(6)) -#define EXTRS (INSN_OP(0x34) | INSN_EXT3SH(7)) -#define VEXTRS (INSN_OP(0x34) | INSN_EXT3SH(5)) - -#define SUBI (INSN_OP(0x25)) -#define MTCTL (INSN_OP(0x00) | INSN_EXT8B(0xc2)) - -#define BL (INSN_OP(0x3a) | INSN_EXT3BR(0)) -#define BLE_SR4 (INSN_OP(0x39) | (1 << 13)) -#define BV (INSN_OP(0x3a) | INSN_EXT3BR(6)) -#define BV_N (INSN_OP(0x3a) | INSN_EXT3BR(6) | 2) -#define LDIL (INSN_OP(0x08)) -#define LDO (INSN_OP(0x0d)) - -#define LDB (INSN_OP(0x10)) -#define LDH (INSN_OP(0x11)) -#define LDW (INSN_OP(0x12)) -#define LDWM (INSN_OP(0x13)) - -#define STB (INSN_OP(0x18)) -#define STH (INSN_OP(0x19)) -#define STW (INSN_OP(0x1a)) -#define STWM (INSN_OP(0x1b)) - -#define COMBT (INSN_OP(0x20)) -#define COMBF (INSN_OP(0x22)) - -static int lowsignext(uint32_t val, int start, int length) -{ - return (((val << 1) & ~(~0 << length)) | - ((val >> (length - 1)) & 1)) << start; -} - -static inline void tcg_out_mov(TCGContext *s, int ret, int arg) -{ - /* PA1.1 defines COPY as OR r,0,t */ - tcg_out32(s, ARITH_OR | INSN_T(ret) | INSN_R1(arg) | INSN_R2(TCG_REG_R0)); - - /* PA2.0 defines COPY as LDO 0(r),t - * but hppa-dis.c is unaware of this definition */ - /* tcg_out32(s, LDO | INSN_R1(ret) | INSN_R2(arg) | reassemble_14(0)); */ -} - -static inline void tcg_out_movi(TCGContext *s, TCGType type, - int ret, tcg_target_long arg) -{ - if (arg == (arg & 0x1fff)) { - tcg_out32(s, LDO | INSN_R1(ret) | INSN_R2(TCG_REG_R0) | - reassemble_14(arg)); - } else { - tcg_out32(s, LDIL | INSN_R2(ret) | - reassemble_21(lrsel((uint32_t)arg, 0))); - if (arg & 0x7ff) - tcg_out32(s, LDO | INSN_R1(ret) | INSN_R2(ret) | - reassemble_14(rrsel((uint32_t)arg, 0))); - } -} - -static inline void tcg_out_ld_raw(TCGContext *s, int ret, - tcg_target_long arg) -{ - tcg_out32(s, LDIL | INSN_R2(ret) | - reassemble_21(lrsel((uint32_t)arg, 0))); - tcg_out32(s, LDW | INSN_R1(ret) | INSN_R2(ret) | - reassemble_14(rrsel((uint32_t)arg, 0))); -} - -static inline void tcg_out_ld_ptr(TCGContext *s, int ret, - tcg_target_long arg) -{ - tcg_out_ld_raw(s, ret, arg); -} - -static inline void tcg_out_ldst(TCGContext *s, int ret, int addr, int offset, - int op) -{ - if (offset == (offset & 0xfff)) - tcg_out32(s, op | INSN_R1(ret) | INSN_R2(addr) | - reassemble_14(offset)); - else { - fprintf(stderr, "unimplemented %s with offset %d\n", __func__, offset); - tcg_abort(); - } -} - -static inline void tcg_out_ld(TCGContext *s, TCGType type, int ret, - int arg1, tcg_target_long arg2) -{ - fprintf(stderr, "unimplemented %s\n", __func__); - tcg_abort(); -} - -static inline void tcg_out_st(TCGContext *s, TCGType type, int ret, - int arg1, tcg_target_long arg2) -{ - fprintf(stderr, "unimplemented %s\n", __func__); - tcg_abort(); -} - -static inline void tcg_out_arith(TCGContext *s, int t, int r1, int r2, int op) -{ - tcg_out32(s, op | INSN_T(t) | INSN_R1(r1) | INSN_R2(r2)); -} - -static inline void tcg_out_arithi(TCGContext *s, int t, int r1, - tcg_target_long val, int op) -{ - tcg_out_movi(s, TCG_TYPE_PTR, TCG_REG_R20, val); - tcg_out_arith(s, t, r1, TCG_REG_R20, op); -} - -static inline void tcg_out_addi(TCGContext *s, int reg, tcg_target_long val) -{ - tcg_out_arithi(s, reg, reg, val, ARITH_ADD); -} - -static inline void tcg_out_nop(TCGContext *s) -{ - tcg_out32(s, ARITH_OR | INSN_T(TCG_REG_R0) | INSN_R1(TCG_REG_R0) | - INSN_R2(TCG_REG_R0)); -} - -static inline void tcg_out_ext8s(TCGContext *s, int ret, int arg) { - tcg_out32(s, EXTRS | INSN_R1(ret) | INSN_R2(arg) | - INSN_SHDEP_P(31) | INSN_DEP_LEN(8)); -} - -static inline void tcg_out_ext16s(TCGContext *s, int ret, int arg) { - tcg_out32(s, EXTRS | INSN_R1(ret) | INSN_R2(arg) | - INSN_SHDEP_P(31) | INSN_DEP_LEN(16)); -} - -static inline void tcg_out_bswap16(TCGContext *s, int ret, int arg) { - if(ret != arg) - tcg_out_mov(s, ret, arg); - tcg_out32(s, DEP | INSN_R2(ret) | INSN_R1(ret) | - INSN_SHDEP_CP(15) | INSN_DEP_LEN(8)); - tcg_out32(s, SHD | INSN_T(ret) | INSN_R1(TCG_REG_R0) | - INSN_R2(ret) | INSN_SHDEP_CP(8)); -} - -static inline void tcg_out_bswap32(TCGContext *s, int ret, int arg, int temp) { - tcg_out32(s, SHD | INSN_T(temp) | INSN_R1(arg) | - INSN_R2(arg) | INSN_SHDEP_CP(16)); - tcg_out32(s, DEP | INSN_R2(temp) | INSN_R1(temp) | - INSN_SHDEP_CP(15) | INSN_DEP_LEN(8)); - tcg_out32(s, SHD | INSN_T(ret) | INSN_R1(arg) | - INSN_R2(temp) | INSN_SHDEP_CP(8)); -} - -static inline void tcg_out_call(TCGContext *s, void *func) -{ - uint32_t val = (uint32_t)__canonicalize_funcptr_for_compare(func); - tcg_out32(s, LDIL | INSN_R2(TCG_REG_R20) | - reassemble_21(lrsel(val, 0))); - tcg_out32(s, BLE_SR4 | INSN_R2(TCG_REG_R20) | - reassemble_17(rrsel(val, 0) >> 2)); - tcg_out_mov(s, TCG_REG_RP, TCG_REG_R31); -} - -#if defined(CONFIG_SOFTMMU) - -#include "../../softmmu_defs.h" - -static void *qemu_ld_helpers[4] = { - __ldb_mmu, - __ldw_mmu, - __ldl_mmu, - __ldq_mmu, -}; - -static void *qemu_st_helpers[4] = { - __stb_mmu, - __stw_mmu, - __stl_mmu, - __stq_mmu, -}; -#endif - -static void tcg_out_qemu_ld(TCGContext *s, const TCGArg *args, int opc) -{ - int addr_reg, data_reg, data_reg2, r0, r1, mem_index, s_bits, bswap; -#if defined(CONFIG_SOFTMMU) - uint32_t *label1_ptr, *label2_ptr; -#endif -#if TARGET_LONG_BITS == 64 -#if defined(CONFIG_SOFTMMU) - uint32_t *label3_ptr; -#endif - int addr_reg2; -#endif - - data_reg = *args++; - if (opc == 3) - data_reg2 = *args++; - else - data_reg2 = 0; /* suppress warning */ - addr_reg = *args++; -#if TARGET_LONG_BITS == 64 - addr_reg2 = *args++; -#endif - mem_index = *args; - s_bits = opc & 3; - - r0 = TCG_REG_R26; - r1 = TCG_REG_R25; - -#if defined(CONFIG_SOFTMMU) - tcg_out_mov(s, r1, addr_reg); - - tcg_out_mov(s, r0, addr_reg); - - tcg_out32(s, SHD | INSN_T(r1) | INSN_R1(TCG_REG_R0) | INSN_R2(r1) | - INSN_SHDEP_CP(TARGET_PAGE_BITS - CPU_TLB_ENTRY_BITS)); - - tcg_out_arithi(s, r0, r0, TARGET_PAGE_MASK | ((1 << s_bits) - 1), - ARITH_AND); - - tcg_out_arithi(s, r1, r1, (CPU_TLB_SIZE - 1) << CPU_TLB_ENTRY_BITS, - ARITH_AND); - - tcg_out_arith(s, r1, r1, TCG_AREG0, ARITH_ADD); - tcg_out_arithi(s, r1, r1, - offsetof(CPUState, tlb_table[mem_index][0].addr_read), - ARITH_ADD); - - tcg_out_ldst(s, TCG_REG_R20, r1, 0, LDW); - -#if TARGET_LONG_BITS == 32 - /* if equal, jump to label1 */ - label1_ptr = (uint32_t *)s->code_ptr; - tcg_out32(s, COMBT | INSN_R1(TCG_REG_R20) | INSN_R2(r0) | - INSN_COND(COND_EQUAL)); - tcg_out_mov(s, r0, addr_reg); /* delay slot */ -#else - /* if not equal, jump to label3 */ - label3_ptr = (uint32_t *)s->code_ptr; - tcg_out32(s, COMBF | INSN_R1(TCG_REG_R20) | INSN_R2(r0) | - INSN_COND(COND_EQUAL)); - tcg_out_mov(s, r0, addr_reg); /* delay slot */ - - tcg_out_ldst(s, TCG_REG_R20, r1, 4, LDW); - - /* if equal, jump to label1 */ - label1_ptr = (uint32_t *)s->code_ptr; - tcg_out32(s, COMBT | INSN_R1(TCG_REG_R20) | INSN_R2(addr_reg2) | - INSN_COND(COND_EQUAL)); - tcg_out_nop(s); /* delay slot */ - - /* label3: */ - *label3_ptr |= reassemble_12((uint32_t *)s->code_ptr - label3_ptr - 2); -#endif - -#if TARGET_LONG_BITS == 32 - tcg_out_mov(s, TCG_REG_R26, addr_reg); - tcg_out_movi(s, TCG_TYPE_I32, TCG_REG_R25, mem_index); -#else - tcg_out_mov(s, TCG_REG_R26, addr_reg); - tcg_out_mov(s, TCG_REG_R25, addr_reg2); - tcg_out_movi(s, TCG_TYPE_I32, TCG_REG_R24, mem_index); -#endif - - tcg_out_call(s, qemu_ld_helpers[s_bits]); - - switch(opc) { - case 0 | 4: - tcg_out_ext8s(s, data_reg, TCG_REG_RET0); - break; - case 1 | 4: - tcg_out_ext16s(s, data_reg, TCG_REG_RET0); - break; - case 0: - case 1: - case 2: - default: - tcg_out_mov(s, data_reg, TCG_REG_RET0); - break; - case 3: - tcg_abort(); - tcg_out_mov(s, data_reg, TCG_REG_RET0); - tcg_out_mov(s, data_reg2, TCG_REG_RET1); - break; - } - - /* jump to label2 */ - label2_ptr = (uint32_t *)s->code_ptr; - tcg_out32(s, BL | INSN_R2(TCG_REG_R0) | 2); - - /* label1: */ - *label1_ptr |= reassemble_12((uint32_t *)s->code_ptr - label1_ptr - 2); - - tcg_out_arithi(s, TCG_REG_R20, r1, - offsetof(CPUTLBEntry, addend) - offsetof(CPUTLBEntry, addr_read), - ARITH_ADD); - tcg_out_ldst(s, TCG_REG_R20, TCG_REG_R20, 0, LDW); - tcg_out_arith(s, r0, r0, TCG_REG_R20, ARITH_ADD); -#else - r0 = addr_reg; -#endif - -#ifdef TARGET_WORDS_BIGENDIAN - bswap = 0; -#else - bswap = 1; -#endif - switch (opc) { - case 0: - tcg_out_ldst(s, data_reg, r0, 0, LDB); - break; - case 0 | 4: - tcg_out_ldst(s, data_reg, r0, 0, LDB); - tcg_out_ext8s(s, data_reg, data_reg); - break; - case 1: - tcg_out_ldst(s, data_reg, r0, 0, LDH); - if (bswap) - tcg_out_bswap16(s, data_reg, data_reg); - break; - case 1 | 4: - tcg_out_ldst(s, data_reg, r0, 0, LDH); - if (bswap) - tcg_out_bswap16(s, data_reg, data_reg); - tcg_out_ext16s(s, data_reg, data_reg); - break; - case 2: - tcg_out_ldst(s, data_reg, r0, 0, LDW); - if (bswap) - tcg_out_bswap32(s, data_reg, data_reg, TCG_REG_R20); - break; - case 3: - tcg_abort(); - if (!bswap) { - tcg_out_ldst(s, data_reg, r0, 0, LDW); - tcg_out_ldst(s, data_reg2, r0, 4, LDW); - } else { - tcg_out_ldst(s, data_reg, r0, 4, LDW); - tcg_out_bswap32(s, data_reg, data_reg, TCG_REG_R20); - tcg_out_ldst(s, data_reg2, r0, 0, LDW); - tcg_out_bswap32(s, data_reg2, data_reg2, TCG_REG_R20); - } - break; - default: - tcg_abort(); - } - -#if defined(CONFIG_SOFTMMU) - /* label2: */ - *label2_ptr |= reassemble_17((uint32_t *)s->code_ptr - label2_ptr - 2); -#endif -} - -static void tcg_out_qemu_st(TCGContext *s, const TCGArg *args, int opc) -{ - int addr_reg, data_reg, data_reg2, r0, r1, mem_index, s_bits, bswap; -#if defined(CONFIG_SOFTMMU) - uint32_t *label1_ptr, *label2_ptr; -#endif -#if TARGET_LONG_BITS == 64 -#if defined(CONFIG_SOFTMMU) - uint32_t *label3_ptr; -#endif - int addr_reg2; -#endif - - data_reg = *args++; - if (opc == 3) - data_reg2 = *args++; - else - data_reg2 = 0; /* suppress warning */ - addr_reg = *args++; -#if TARGET_LONG_BITS == 64 - addr_reg2 = *args++; -#endif - mem_index = *args; - - s_bits = opc; - - r0 = TCG_REG_R26; - r1 = TCG_REG_R25; - -#if defined(CONFIG_SOFTMMU) - tcg_out_mov(s, r1, addr_reg); - - tcg_out_mov(s, r0, addr_reg); - - tcg_out32(s, SHD | INSN_T(r1) | INSN_R1(TCG_REG_R0) | INSN_R2(r1) | - INSN_SHDEP_CP(TARGET_PAGE_BITS - CPU_TLB_ENTRY_BITS)); - - tcg_out_arithi(s, r0, r0, TARGET_PAGE_MASK | ((1 << s_bits) - 1), - ARITH_AND); - - tcg_out_arithi(s, r1, r1, (CPU_TLB_SIZE - 1) << CPU_TLB_ENTRY_BITS, - ARITH_AND); - - tcg_out_arith(s, r1, r1, TCG_AREG0, ARITH_ADD); - tcg_out_arithi(s, r1, r1, - offsetof(CPUState, tlb_table[mem_index][0].addr_write), - ARITH_ADD); - - tcg_out_ldst(s, TCG_REG_R20, r1, 0, LDW); - -#if TARGET_LONG_BITS == 32 - /* if equal, jump to label1 */ - label1_ptr = (uint32_t *)s->code_ptr; - tcg_out32(s, COMBT | INSN_R1(TCG_REG_R20) | INSN_R2(r0) | - INSN_COND(COND_EQUAL)); - tcg_out_mov(s, r0, addr_reg); /* delay slot */ -#else - /* if not equal, jump to label3 */ - label3_ptr = (uint32_t *)s->code_ptr; - tcg_out32(s, COMBF | INSN_R1(TCG_REG_R20) | INSN_R2(r0) | - INSN_COND(COND_EQUAL)); - tcg_out_mov(s, r0, addr_reg); /* delay slot */ - - tcg_out_ldst(s, TCG_REG_R20, r1, 4, LDW); - - /* if equal, jump to label1 */ - label1_ptr = (uint32_t *)s->code_ptr; - tcg_out32(s, COMBT | INSN_R1(TCG_REG_R20) | INSN_R2(addr_reg2) | - INSN_COND(COND_EQUAL)); - tcg_out_nop(s); /* delay slot */ - - /* label3: */ - *label3_ptr |= reassemble_12((uint32_t *)s->code_ptr - label3_ptr - 2); -#endif - - tcg_out_mov(s, TCG_REG_R26, addr_reg); -#if TARGET_LONG_BITS == 64 - tcg_out_mov(s, TCG_REG_R25, addr_reg2); - if (opc == 3) { - tcg_abort(); - tcg_out_mov(s, TCG_REG_R24, data_reg); - tcg_out_mov(s, TCG_REG_R23, data_reg2); - /* TODO: push mem_index */ - tcg_abort(); - } else { - switch(opc) { - case 0: - tcg_out32(s, EXTRU | INSN_R1(TCG_REG_R24) | INSN_R2(data_reg) | - INSN_SHDEP_P(31) | INSN_DEP_LEN(8)); - break; - case 1: - tcg_out32(s, EXTRU | INSN_R1(TCG_REG_R24) | INSN_R2(data_reg) | - INSN_SHDEP_P(31) | INSN_DEP_LEN(16)); - break; - case 2: - tcg_out_mov(s, TCG_REG_R24, data_reg); - break; - } - tcg_out_movi(s, TCG_TYPE_I32, TCG_REG_R23, mem_index); - } -#else - if (opc == 3) { - tcg_abort(); - tcg_out_mov(s, TCG_REG_R25, data_reg); - tcg_out_mov(s, TCG_REG_R24, data_reg2); - tcg_out_movi(s, TCG_TYPE_I32, TCG_REG_R23, mem_index); - } else { - switch(opc) { - case 0: - tcg_out32(s, EXTRU | INSN_R1(TCG_REG_R25) | INSN_R2(data_reg) | - INSN_SHDEP_P(31) | INSN_DEP_LEN(8)); - break; - case 1: - tcg_out32(s, EXTRU | INSN_R1(TCG_REG_R25) | INSN_R2(data_reg) | - INSN_SHDEP_P(31) | INSN_DEP_LEN(16)); - break; - case 2: - tcg_out_mov(s, TCG_REG_R25, data_reg); - break; - } - tcg_out_movi(s, TCG_TYPE_I32, TCG_REG_R24, mem_index); - } -#endif - tcg_out_call(s, qemu_st_helpers[s_bits]); - - /* jump to label2 */ - label2_ptr = (uint32_t *)s->code_ptr; - tcg_out32(s, BL | INSN_R2(TCG_REG_R0) | 2); - - /* label1: */ - *label1_ptr |= reassemble_12((uint32_t *)s->code_ptr - label1_ptr - 2); - - tcg_out_arithi(s, TCG_REG_R20, r1, - offsetof(CPUTLBEntry, addend) - offsetof(CPUTLBEntry, addr_write), - ARITH_ADD); - tcg_out_ldst(s, TCG_REG_R20, TCG_REG_R20, 0, LDW); - tcg_out_arith(s, r0, r0, TCG_REG_R20, ARITH_ADD); -#else - r0 = addr_reg; -#endif - -#ifdef TARGET_WORDS_BIGENDIAN - bswap = 0; -#else - bswap = 1; -#endif - switch (opc) { - case 0: - tcg_out_ldst(s, data_reg, r0, 0, STB); - break; - case 1: - if (bswap) { - tcg_out_bswap16(s, TCG_REG_R20, data_reg); - data_reg = TCG_REG_R20; - } - tcg_out_ldst(s, data_reg, r0, 0, STH); - break; - case 2: - if (bswap) { - tcg_out_bswap32(s, TCG_REG_R20, data_reg, TCG_REG_R20); - data_reg = TCG_REG_R20; - } - tcg_out_ldst(s, data_reg, r0, 0, STW); - break; - case 3: - tcg_abort(); - if (!bswap) { - tcg_out_ldst(s, data_reg, r0, 0, STW); - tcg_out_ldst(s, data_reg2, r0, 4, STW); - } else { - tcg_out_bswap32(s, TCG_REG_R20, data_reg, TCG_REG_R20); - tcg_out_ldst(s, TCG_REG_R20, r0, 4, STW); - tcg_out_bswap32(s, TCG_REG_R20, data_reg2, TCG_REG_R20); - tcg_out_ldst(s, TCG_REG_R20, r0, 0, STW); - } - break; - default: - tcg_abort(); - } - -#if defined(CONFIG_SOFTMMU) - /* label2: */ - *label2_ptr |= reassemble_17((uint32_t *)s->code_ptr - label2_ptr - 2); -#endif -} - -static inline void tcg_out_op(TCGContext *s, int opc, const TCGArg *args, - const int *const_args) -{ - int c; - - switch (opc) { - case INDEX_op_exit_tb: - tcg_out_movi(s, TCG_TYPE_PTR, TCG_REG_RET0, args[0]); - tcg_out32(s, BV_N | INSN_R2(TCG_REG_R18)); - break; - case INDEX_op_goto_tb: - if (s->tb_jmp_offset) { - /* direct jump method */ - fprintf(stderr, "goto_tb direct\n"); - tcg_abort(); - tcg_out_movi(s, TCG_TYPE_PTR, TCG_REG_R20, args[0]); - tcg_out32(s, BV_N | INSN_R2(TCG_REG_R20)); - s->tb_jmp_offset[args[0]] = s->code_ptr - s->code_buf; - } else { - /* indirect jump method */ - tcg_out_ld_ptr(s, TCG_REG_R20, - (tcg_target_long)(s->tb_next + args[0])); - tcg_out32(s, BV_N | INSN_R2(TCG_REG_R20)); - } - s->tb_next_offset[args[0]] = s->code_ptr - s->code_buf; - break; - case INDEX_op_call: - tcg_out32(s, BLE_SR4 | INSN_R2(args[0])); - tcg_out_mov(s, TCG_REG_RP, TCG_REG_R31); - break; - case INDEX_op_jmp: - fprintf(stderr, "unimplemented jmp\n"); - tcg_abort(); - break; - case INDEX_op_br: - fprintf(stderr, "unimplemented br\n"); - tcg_abort(); - break; - case INDEX_op_movi_i32: - tcg_out_movi(s, TCG_TYPE_I32, args[0], (uint32_t)args[1]); - break; - - case INDEX_op_ld8u_i32: - tcg_out_ldst(s, args[0], args[1], args[2], LDB); - break; - case INDEX_op_ld8s_i32: - tcg_out_ldst(s, args[0], args[1], args[2], LDB); - tcg_out_ext8s(s, args[0], args[0]); - break; - case INDEX_op_ld16u_i32: - tcg_out_ldst(s, args[0], args[1], args[2], LDH); - break; - case INDEX_op_ld16s_i32: - tcg_out_ldst(s, args[0], args[1], args[2], LDH); - tcg_out_ext16s(s, args[0], args[0]); - break; - case INDEX_op_ld_i32: - tcg_out_ldst(s, args[0], args[1], args[2], LDW); - break; - - case INDEX_op_st8_i32: - tcg_out_ldst(s, args[0], args[1], args[2], STB); - break; - case INDEX_op_st16_i32: - tcg_out_ldst(s, args[0], args[1], args[2], STH); - break; - case INDEX_op_st_i32: - tcg_out_ldst(s, args[0], args[1], args[2], STW); - break; - - case INDEX_op_sub_i32: - c = ARITH_SUB; - goto gen_arith; - case INDEX_op_and_i32: - c = ARITH_AND; - goto gen_arith; - case INDEX_op_or_i32: - c = ARITH_OR; - goto gen_arith; - case INDEX_op_xor_i32: - c = ARITH_XOR; - goto gen_arith; - case INDEX_op_add_i32: - c = ARITH_ADD; - goto gen_arith; - - case INDEX_op_shl_i32: - tcg_out32(s, SUBI | INSN_R1(TCG_REG_R20) | INSN_R2(args[2]) | - lowsignext(0x1f, 0, 11)); - tcg_out32(s, MTCTL | INSN_R2(11) | INSN_R1(TCG_REG_R20)); - tcg_out32(s, ZVDEP | INSN_R2(args[0]) | INSN_R1(args[1]) | - INSN_DEP_LEN(32)); - break; - case INDEX_op_shr_i32: - tcg_out32(s, MTCTL | INSN_R2(11) | INSN_R1(args[2])); - tcg_out32(s, VSHD | INSN_T(args[0]) | INSN_R1(TCG_REG_R0) | - INSN_R2(args[1])); - break; - case INDEX_op_sar_i32: - tcg_out32(s, SUBI | INSN_R1(TCG_REG_R20) | INSN_R2(args[2]) | - lowsignext(0x1f, 0, 11)); - tcg_out32(s, MTCTL | INSN_R2(11) | INSN_R1(TCG_REG_R20)); - tcg_out32(s, VEXTRS | INSN_R1(args[0]) | INSN_R2(args[1]) | - INSN_DEP_LEN(32)); - break; - - case INDEX_op_mul_i32: - fprintf(stderr, "unimplemented mul\n"); - tcg_abort(); - break; - case INDEX_op_mulu2_i32: - fprintf(stderr, "unimplemented mulu2\n"); - tcg_abort(); - break; - case INDEX_op_div2_i32: - fprintf(stderr, "unimplemented div2\n"); - tcg_abort(); - break; - case INDEX_op_divu2_i32: - fprintf(stderr, "unimplemented divu2\n"); - tcg_abort(); - break; - - case INDEX_op_brcond_i32: - fprintf(stderr, "unimplemented brcond\n"); - tcg_abort(); - break; - - case INDEX_op_qemu_ld8u: - tcg_out_qemu_ld(s, args, 0); - break; - case INDEX_op_qemu_ld8s: - tcg_out_qemu_ld(s, args, 0 | 4); - break; - case INDEX_op_qemu_ld16u: - tcg_out_qemu_ld(s, args, 1); - break; - case INDEX_op_qemu_ld16s: - tcg_out_qemu_ld(s, args, 1 | 4); - break; - case INDEX_op_qemu_ld32u: - tcg_out_qemu_ld(s, args, 2); - break; - - case INDEX_op_qemu_st8: - tcg_out_qemu_st(s, args, 0); - break; - case INDEX_op_qemu_st16: - tcg_out_qemu_st(s, args, 1); - break; - case INDEX_op_qemu_st32: - tcg_out_qemu_st(s, args, 2); - break; - - default: - fprintf(stderr, "unknown opcode 0x%x\n", opc); - tcg_abort(); - } - return; - -gen_arith: - tcg_out_arith(s, args[0], args[1], args[2], c); -} - -static const TCGTargetOpDef hppa_op_defs[] = { - { INDEX_op_exit_tb, { } }, - { INDEX_op_goto_tb, { } }, - - { INDEX_op_call, { "r" } }, - { INDEX_op_jmp, { "r" } }, - { INDEX_op_br, { } }, - - { INDEX_op_mov_i32, { "r", "r" } }, - { INDEX_op_movi_i32, { "r" } }, - { INDEX_op_ld8u_i32, { "r", "r" } }, - { INDEX_op_ld8s_i32, { "r", "r" } }, - { INDEX_op_ld16u_i32, { "r", "r" } }, - { INDEX_op_ld16s_i32, { "r", "r" } }, - { INDEX_op_ld_i32, { "r", "r" } }, - { INDEX_op_st8_i32, { "r", "r" } }, - { INDEX_op_st16_i32, { "r", "r" } }, - { INDEX_op_st_i32, { "r", "r" } }, - - { INDEX_op_add_i32, { "r", "r", "r" } }, - { INDEX_op_sub_i32, { "r", "r", "r" } }, - { INDEX_op_and_i32, { "r", "r", "r" } }, - { INDEX_op_or_i32, { "r", "r", "r" } }, - { INDEX_op_xor_i32, { "r", "r", "r" } }, - - { INDEX_op_shl_i32, { "r", "r", "r" } }, - { INDEX_op_shr_i32, { "r", "r", "r" } }, - { INDEX_op_sar_i32, { "r", "r", "r" } }, - - { INDEX_op_brcond_i32, { "r", "r" } }, - -#if TARGET_LONG_BITS == 32 - { INDEX_op_qemu_ld8u, { "r", "L" } }, - { INDEX_op_qemu_ld8s, { "r", "L" } }, - { INDEX_op_qemu_ld16u, { "r", "L" } }, - { INDEX_op_qemu_ld16s, { "r", "L" } }, - { INDEX_op_qemu_ld32u, { "r", "L" } }, - { INDEX_op_qemu_ld64, { "r", "r", "L" } }, - - { INDEX_op_qemu_st8, { "L", "L" } }, - { INDEX_op_qemu_st16, { "L", "L" } }, - { INDEX_op_qemu_st32, { "L", "L" } }, - { INDEX_op_qemu_st64, { "L", "L", "L" } }, -#else - { INDEX_op_qemu_ld8u, { "r", "L", "L" } }, - { INDEX_op_qemu_ld8s, { "r", "L", "L" } }, - { INDEX_op_qemu_ld16u, { "r", "L", "L" } }, - { INDEX_op_qemu_ld16s, { "r", "L", "L" } }, - { INDEX_op_qemu_ld32u, { "r", "L", "L" } }, - { INDEX_op_qemu_ld32s, { "r", "L", "L" } }, - { INDEX_op_qemu_ld64, { "r", "r", "L", "L" } }, - - { INDEX_op_qemu_st8, { "L", "L", "L" } }, - { INDEX_op_qemu_st16, { "L", "L", "L" } }, - { INDEX_op_qemu_st32, { "L", "L", "L" } }, - { INDEX_op_qemu_st64, { "L", "L", "L", "L" } }, -#endif - { -1 }, -}; - -void tcg_target_init(TCGContext *s) -{ - tcg_regset_set32(tcg_target_available_regs[TCG_TYPE_I32], 0, 0xffffffff); - tcg_regset_set32(tcg_target_call_clobber_regs, 0, - (1 << TCG_REG_R20) | - (1 << TCG_REG_R21) | - (1 << TCG_REG_R22) | - (1 << TCG_REG_R23) | - (1 << TCG_REG_R24) | - (1 << TCG_REG_R25) | - (1 << TCG_REG_R26)); - - tcg_regset_clear(s->reserved_regs); - tcg_regset_set_reg(s->reserved_regs, TCG_REG_R0); /* hardwired to zero */ - tcg_regset_set_reg(s->reserved_regs, TCG_REG_R1); /* addil target */ - tcg_regset_set_reg(s->reserved_regs, TCG_REG_RP); /* link register */ - tcg_regset_set_reg(s->reserved_regs, TCG_REG_R3); /* frame pointer */ - tcg_regset_set_reg(s->reserved_regs, TCG_REG_R18); /* return pointer */ - tcg_regset_set_reg(s->reserved_regs, TCG_REG_R19); /* clobbered w/o pic */ - tcg_regset_set_reg(s->reserved_regs, TCG_REG_R20); /* reserved */ - tcg_regset_set_reg(s->reserved_regs, TCG_REG_DP); /* data pointer */ - tcg_regset_set_reg(s->reserved_regs, TCG_REG_SP); /* stack pointer */ - tcg_regset_set_reg(s->reserved_regs, TCG_REG_R31); /* ble link reg */ - - tcg_add_target_add_op_defs(hppa_op_defs); -} diff --git a/qemu/qemu-git/tcg/hppa/.svn/text-base/tcg-target.h.svn-base b/qemu/qemu-git/tcg/hppa/.svn/text-base/tcg-target.h.svn-base deleted file mode 100644 index 7ab6f0c..0000000 --- a/qemu/qemu-git/tcg/hppa/.svn/text-base/tcg-target.h.svn-base +++ /dev/null @@ -1,203 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2008 Fabrice Bellard - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ - -#define TCG_TARGET_HPPA 1 - -#if defined(_PA_RISC1_1) -#define TCG_TARGET_REG_BITS 32 -#else -#error unsupported -#endif - -#define TCG_TARGET_WORDS_BIGENDIAN - -#define TCG_TARGET_NB_REGS 32 - -enum { - TCG_REG_R0 = 0, - TCG_REG_R1, - TCG_REG_RP, - TCG_REG_R3, - TCG_REG_R4, - TCG_REG_R5, - TCG_REG_R6, - TCG_REG_R7, - TCG_REG_R8, - TCG_REG_R9, - TCG_REG_R10, - TCG_REG_R11, - TCG_REG_R12, - TCG_REG_R13, - TCG_REG_R14, - TCG_REG_R15, - TCG_REG_R16, - TCG_REG_R17, - TCG_REG_R18, - TCG_REG_R19, - TCG_REG_R20, - TCG_REG_R21, - TCG_REG_R22, - TCG_REG_R23, - TCG_REG_R24, - TCG_REG_R25, - TCG_REG_R26, - TCG_REG_DP, - TCG_REG_RET0, - TCG_REG_RET1, - TCG_REG_SP, - TCG_REG_R31, -}; - -/* used for function call generation */ -#define TCG_REG_CALL_STACK TCG_REG_SP -#define TCG_TARGET_STACK_ALIGN 16 -#define TCG_TARGET_STACK_GROWSUP - -/* optional instructions */ -//#define TCG_TARGET_HAS_ext8s_i32 -//#define TCG_TARGET_HAS_ext16s_i32 -//#define TCG_TARGET_HAS_bswap16_i32 -//#define TCG_TARGET_HAS_bswap32_i32 - -/* Note: must be synced with dyngen-exec.h */ -#define TCG_AREG0 TCG_REG_R17 -#define TCG_AREG1 TCG_REG_R14 -#define TCG_AREG2 TCG_REG_R15 - -static inline void flush_icache_range(unsigned long start, unsigned long stop) -{ - start &= ~31; - while (start <= stop) - { - asm volatile ("fdc 0(%0)\n" - "sync\n" - "fic 0(%%sr4, %0)\n" - "sync\n" - : : "r"(start) : "memory"); - start += 32; - } -} - -/* supplied by libgcc */ -extern void *__canonicalize_funcptr_for_compare(void *); - -/* Field selection types defined by hppa */ -#define rnd(x) (((x)+0x1000)&~0x1fff) -/* lsel: select left 21 bits */ -#define lsel(v,a) (((v)+(a))>>11) -/* rsel: select right 11 bits */ -#define rsel(v,a) (((v)+(a))&0x7ff) -/* lrsel with rounding of addend to nearest 8k */ -#define lrsel(v,a) (((v)+rnd(a))>>11) -/* rrsel with rounding of addend to nearest 8k */ -#define rrsel(v,a) ((((v)+rnd(a))&0x7ff)+((a)-rnd(a))) - -#define mask(x,sz) ((x) & ~((1<<(sz))-1)) - -static inline int reassemble_12(int as12) -{ - return (((as12 & 0x800) >> 11) | - ((as12 & 0x400) >> 8) | - ((as12 & 0x3ff) << 3)); -} - -static inline int reassemble_14(int as14) -{ - return (((as14 & 0x1fff) << 1) | - ((as14 & 0x2000) >> 13)); -} - -static inline int reassemble_17(int as17) -{ - return (((as17 & 0x10000) >> 16) | - ((as17 & 0x0f800) << 5) | - ((as17 & 0x00400) >> 8) | - ((as17 & 0x003ff) << 3)); -} - -static inline int reassemble_21(int as21) -{ - return (((as21 & 0x100000) >> 20) | - ((as21 & 0x0ffe00) >> 8) | - ((as21 & 0x000180) << 7) | - ((as21 & 0x00007c) << 14) | - ((as21 & 0x000003) << 12)); -} - -static inline void hppa_patch21l(uint32_t *insn, int val, int addend) -{ - val = lrsel(val, addend); - *insn = mask(*insn, 21) | reassemble_21(val); -} - -static inline void hppa_patch14r(uint32_t *insn, int val, int addend) -{ - val = rrsel(val, addend); - *insn = mask(*insn, 14) | reassemble_14(val); -} - -static inline void hppa_patch17r(uint32_t *insn, int val, int addend) -{ - val = rrsel(val, addend); - *insn = (*insn & ~0x1f1ffd) | reassemble_17(val); -} - - -static inline void hppa_patch21l_dprel(uint32_t *insn, int val, int addend) -{ - register unsigned int dp asm("r27"); - hppa_patch21l(insn, val - dp, addend); -} - -static inline void hppa_patch14r_dprel(uint32_t *insn, int val, int addend) -{ - register unsigned int dp asm("r27"); - hppa_patch14r(insn, val - dp, addend); -} - -static inline void hppa_patch17f(uint32_t *insn, int val, int addend) -{ - int dot = (int)insn & ~0x3; - int v = ((val + addend) - dot - 8) / 4; - if (v > (1 << 16) || v < -(1 << 16)) { - printf("cannot fit branch to offset %d [%08x->%08x]\n", v, dot, val); - abort(); - } - *insn = (*insn & ~0x1f1ffd) | reassemble_17(v); -} - -static inline void hppa_load_imm21l(uint32_t *insn, int val, int addend) -{ - /* Transform addil L'sym(%dp) to ldil L'val, %r1 */ - *insn = 0x20200000 | reassemble_21(lrsel(val, 0)); -} - -static inline void hppa_load_imm14r(uint32_t *insn, int val, int addend) -{ - /* Transform ldw R'sym(%r1), %rN to ldo R'sym(%r1), %rN */ - hppa_patch14r(insn, val, addend); - /* HACK */ - if (addend == 0) - *insn = (*insn & ~0xfc000000) | (0x0d << 26); -} diff --git a/qemu/qemu-git/tcg/i386/.svn/all-wcprops b/qemu/qemu-git/tcg/i386/.svn/all-wcprops deleted file mode 100644 index 2d55167..0000000 --- a/qemu/qemu-git/tcg/i386/.svn/all-wcprops +++ /dev/null @@ -1,17 +0,0 @@ -K 25 -svn:wc:ra_dav:version-url -V 48 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/i386 -END -tcg-target.c -K 25 -svn:wc:ra_dav:version-url -V 61 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/i386/tcg-target.c -END -tcg-target.h -K 25 -svn:wc:ra_dav:version-url -V 61 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/i386/tcg-target.h -END diff --git a/qemu/qemu-git/tcg/i386/.svn/entries b/qemu/qemu-git/tcg/i386/.svn/entries deleted file mode 100644 index 17ad076..0000000 --- a/qemu/qemu-git/tcg/i386/.svn/entries +++ /dev/null @@ -1,96 +0,0 @@ -10 - -dir -11 -http://svn.code.sf.net/p/x49gp/code/qemu/qemu-git/tcg/i386 -http://svn.code.sf.net/p/x49gp/code - - - -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - -481df3bd-3408-496c-b7de-451e46197bb5 - -tcg-target.c -file - - - - -2013-08-23T00:54:47.000000Z -e6cfada3d8e7203f6a2223f242f47b7b -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -36927 - -tcg-target.h -file - - - - -2013-08-23T00:54:47.000000Z -3f7c3401b361f0d144361293a009fee9 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -2167 - diff --git a/qemu/qemu-git/tcg/i386/.svn/text-base/tcg-target.c.svn-base b/qemu/qemu-git/tcg/i386/.svn/text-base/tcg-target.c.svn-base deleted file mode 100644 index 972b102..0000000 --- a/qemu/qemu-git/tcg/i386/.svn/text-base/tcg-target.c.svn-base +++ /dev/null @@ -1,1262 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2008 Fabrice Bellard - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ - -#ifndef NDEBUG -static const char * const tcg_target_reg_names[TCG_TARGET_NB_REGS] = { - "%eax", - "%ecx", - "%edx", - "%ebx", - "%esp", - "%ebp", - "%esi", - "%edi", -}; -#endif - -static const int tcg_target_reg_alloc_order[] = { - TCG_REG_EAX, - TCG_REG_EDX, - TCG_REG_ECX, - TCG_REG_EBX, - TCG_REG_ESI, - TCG_REG_EDI, - TCG_REG_EBP, -}; - -static const int tcg_target_call_iarg_regs[3] = { TCG_REG_EAX, TCG_REG_EDX, TCG_REG_ECX }; -static const int tcg_target_call_oarg_regs[2] = { TCG_REG_EAX, TCG_REG_EDX }; - -static uint8_t *tb_ret_addr; - -static void patch_reloc(uint8_t *code_ptr, int type, - tcg_target_long value, tcg_target_long addend) -{ - value += addend; - switch(type) { - case R_386_32: - *(uint32_t *)code_ptr = value; - break; - case R_386_PC32: - *(uint32_t *)code_ptr = value - (long)code_ptr; - break; - default: - tcg_abort(); - } -} - -/* maximum number of register used for input function arguments */ -static inline int tcg_target_get_call_iarg_regs_count(int flags) -{ - flags &= TCG_CALL_TYPE_MASK; - switch(flags) { - case TCG_CALL_TYPE_STD: - return 0; - case TCG_CALL_TYPE_REGPARM_1: - case TCG_CALL_TYPE_REGPARM_2: - case TCG_CALL_TYPE_REGPARM: - return flags - TCG_CALL_TYPE_REGPARM_1 + 1; - default: - tcg_abort(); - } -} - -/* parse target specific constraints */ -static int target_parse_constraint(TCGArgConstraint *ct, const char **pct_str) -{ - const char *ct_str; - - ct_str = *pct_str; - switch(ct_str[0]) { - case 'a': - ct->ct |= TCG_CT_REG; - tcg_regset_set_reg(ct->u.regs, TCG_REG_EAX); - break; - case 'b': - ct->ct |= TCG_CT_REG; - tcg_regset_set_reg(ct->u.regs, TCG_REG_EBX); - break; - case 'c': - ct->ct |= TCG_CT_REG; - tcg_regset_set_reg(ct->u.regs, TCG_REG_ECX); - break; - case 'd': - ct->ct |= TCG_CT_REG; - tcg_regset_set_reg(ct->u.regs, TCG_REG_EDX); - break; - case 'S': - ct->ct |= TCG_CT_REG; - tcg_regset_set_reg(ct->u.regs, TCG_REG_ESI); - break; - case 'D': - ct->ct |= TCG_CT_REG; - tcg_regset_set_reg(ct->u.regs, TCG_REG_EDI); - break; - case 'q': - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, 0xf); - break; - case 'r': - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, 0xff); - break; - - /* qemu_ld/st address constraint */ - case 'L': - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, 0xff); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_EAX); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_EDX); - break; - default: - return -1; - } - ct_str++; - *pct_str = ct_str; - return 0; -} - -/* test if a constant matches the constraint */ -static inline int tcg_target_const_match(tcg_target_long val, - const TCGArgConstraint *arg_ct) -{ - int ct; - ct = arg_ct->ct; - if (ct & TCG_CT_CONST) - return 1; - else - return 0; -} - -#define ARITH_ADD 0 -#define ARITH_OR 1 -#define ARITH_ADC 2 -#define ARITH_SBB 3 -#define ARITH_AND 4 -#define ARITH_SUB 5 -#define ARITH_XOR 6 -#define ARITH_CMP 7 - -#define SHIFT_ROL 0 -#define SHIFT_ROR 1 -#define SHIFT_SHL 4 -#define SHIFT_SHR 5 -#define SHIFT_SAR 7 - -#define JCC_JMP (-1) -#define JCC_JO 0x0 -#define JCC_JNO 0x1 -#define JCC_JB 0x2 -#define JCC_JAE 0x3 -#define JCC_JE 0x4 -#define JCC_JNE 0x5 -#define JCC_JBE 0x6 -#define JCC_JA 0x7 -#define JCC_JS 0x8 -#define JCC_JNS 0x9 -#define JCC_JP 0xa -#define JCC_JNP 0xb -#define JCC_JL 0xc -#define JCC_JGE 0xd -#define JCC_JLE 0xe -#define JCC_JG 0xf - -#define P_EXT 0x100 /* 0x0f opcode prefix */ - -static const uint8_t tcg_cond_to_jcc[10] = { - [TCG_COND_EQ] = JCC_JE, - [TCG_COND_NE] = JCC_JNE, - [TCG_COND_LT] = JCC_JL, - [TCG_COND_GE] = JCC_JGE, - [TCG_COND_LE] = JCC_JLE, - [TCG_COND_GT] = JCC_JG, - [TCG_COND_LTU] = JCC_JB, - [TCG_COND_GEU] = JCC_JAE, - [TCG_COND_LEU] = JCC_JBE, - [TCG_COND_GTU] = JCC_JA, -}; - -static inline void tcg_out_opc(TCGContext *s, int opc) -{ - if (opc & P_EXT) - tcg_out8(s, 0x0f); - tcg_out8(s, opc); -} - -static inline void tcg_out_modrm(TCGContext *s, int opc, int r, int rm) -{ - tcg_out_opc(s, opc); - tcg_out8(s, 0xc0 | (r << 3) | rm); -} - -/* rm == -1 means no register index */ -static inline void tcg_out_modrm_offset(TCGContext *s, int opc, int r, int rm, - int32_t offset) -{ - tcg_out_opc(s, opc); - if (rm == -1) { - tcg_out8(s, 0x05 | (r << 3)); - tcg_out32(s, offset); - } else if (offset == 0 && rm != TCG_REG_EBP) { - if (rm == TCG_REG_ESP) { - tcg_out8(s, 0x04 | (r << 3)); - tcg_out8(s, 0x24); - } else { - tcg_out8(s, 0x00 | (r << 3) | rm); - } - } else if ((int8_t)offset == offset) { - if (rm == TCG_REG_ESP) { - tcg_out8(s, 0x44 | (r << 3)); - tcg_out8(s, 0x24); - } else { - tcg_out8(s, 0x40 | (r << 3) | rm); - } - tcg_out8(s, offset); - } else { - if (rm == TCG_REG_ESP) { - tcg_out8(s, 0x84 | (r << 3)); - tcg_out8(s, 0x24); - } else { - tcg_out8(s, 0x80 | (r << 3) | rm); - } - tcg_out32(s, offset); - } -} - -static inline void tcg_out_mov(TCGContext *s, int ret, int arg) -{ - if (arg != ret) - tcg_out_modrm(s, 0x8b, ret, arg); -} - -static inline void tcg_out_movi(TCGContext *s, TCGType type, - int ret, int32_t arg) -{ - if (arg == 0) { - /* xor r0,r0 */ - tcg_out_modrm(s, 0x01 | (ARITH_XOR << 3), ret, ret); - } else { - tcg_out8(s, 0xb8 + ret); - tcg_out32(s, arg); - } -} - -static inline void tcg_out_ld(TCGContext *s, TCGType type, int ret, - int arg1, tcg_target_long arg2) -{ - /* movl */ - tcg_out_modrm_offset(s, 0x8b, ret, arg1, arg2); -} - -static inline void tcg_out_st(TCGContext *s, TCGType type, int arg, - int arg1, tcg_target_long arg2) -{ - /* movl */ - tcg_out_modrm_offset(s, 0x89, arg, arg1, arg2); -} - -static inline void tgen_arithi(TCGContext *s, int c, int r0, int32_t val, int cf) -{ - if (!cf && ((c == ARITH_ADD && val == 1) || (c == ARITH_SUB && val == -1))) { - /* inc */ - tcg_out_opc(s, 0x40 + r0); - } else if (!cf && ((c == ARITH_ADD && val == -1) || (c == ARITH_SUB && val == 1))) { - /* dec */ - tcg_out_opc(s, 0x48 + r0); - } else if (val == (int8_t)val) { - tcg_out_modrm(s, 0x83, c, r0); - tcg_out8(s, val); - } else if (c == ARITH_AND && val == 0xffu && r0 < 4) { - /* movzbl */ - tcg_out_modrm(s, 0xb6 | P_EXT, r0, r0); - } else if (c == ARITH_AND && val == 0xffffu) { - /* movzwl */ - tcg_out_modrm(s, 0xb7 | P_EXT, r0, r0); - } else { - tcg_out_modrm(s, 0x81, c, r0); - tcg_out32(s, val); - } -} - -static void tcg_out_addi(TCGContext *s, int reg, tcg_target_long val) -{ - if (val != 0) - tgen_arithi(s, ARITH_ADD, reg, val, 0); -} - -static void tcg_out_jxx(TCGContext *s, int opc, int label_index) -{ - int32_t val, val1; - TCGLabel *l = &s->labels[label_index]; - - if (l->has_value) { - val = l->u.value - (tcg_target_long)s->code_ptr; - val1 = val - 2; - if ((int8_t)val1 == val1) { - if (opc == -1) - tcg_out8(s, 0xeb); - else - tcg_out8(s, 0x70 + opc); - tcg_out8(s, val1); - } else { - if (opc == -1) { - tcg_out8(s, 0xe9); - tcg_out32(s, val - 5); - } else { - tcg_out8(s, 0x0f); - tcg_out8(s, 0x80 + opc); - tcg_out32(s, val - 6); - } - } - } else { - if (opc == -1) { - tcg_out8(s, 0xe9); - } else { - tcg_out8(s, 0x0f); - tcg_out8(s, 0x80 + opc); - } - tcg_out_reloc(s, s->code_ptr, R_386_PC32, label_index, -4); - s->code_ptr += 4; - } -} - -static void tcg_out_brcond(TCGContext *s, int cond, - TCGArg arg1, TCGArg arg2, int const_arg2, - int label_index) -{ - if (const_arg2) { - if (arg2 == 0) { - /* test r, r */ - tcg_out_modrm(s, 0x85, arg1, arg1); - } else { - tgen_arithi(s, ARITH_CMP, arg1, arg2, 0); - } - } else { - tcg_out_modrm(s, 0x01 | (ARITH_CMP << 3), arg2, arg1); - } - tcg_out_jxx(s, tcg_cond_to_jcc[cond], label_index); -} - -/* XXX: we implement it at the target level to avoid having to - handle cross basic blocks temporaries */ -static void tcg_out_brcond2(TCGContext *s, - const TCGArg *args, const int *const_args) -{ - int label_next; - label_next = gen_new_label(); - switch(args[4]) { - case TCG_COND_EQ: - tcg_out_brcond(s, TCG_COND_NE, args[0], args[2], const_args[2], label_next); - tcg_out_brcond(s, TCG_COND_EQ, args[1], args[3], const_args[3], args[5]); - break; - case TCG_COND_NE: - tcg_out_brcond(s, TCG_COND_NE, args[0], args[2], const_args[2], args[5]); - tcg_out_brcond(s, TCG_COND_NE, args[1], args[3], const_args[3], args[5]); - break; - case TCG_COND_LT: - tcg_out_brcond(s, TCG_COND_LT, args[1], args[3], const_args[3], args[5]); - tcg_out_jxx(s, JCC_JNE, label_next); - tcg_out_brcond(s, TCG_COND_LTU, args[0], args[2], const_args[2], args[5]); - break; - case TCG_COND_LE: - tcg_out_brcond(s, TCG_COND_LT, args[1], args[3], const_args[3], args[5]); - tcg_out_jxx(s, JCC_JNE, label_next); - tcg_out_brcond(s, TCG_COND_LEU, args[0], args[2], const_args[2], args[5]); - break; - case TCG_COND_GT: - tcg_out_brcond(s, TCG_COND_GT, args[1], args[3], const_args[3], args[5]); - tcg_out_jxx(s, JCC_JNE, label_next); - tcg_out_brcond(s, TCG_COND_GTU, args[0], args[2], const_args[2], args[5]); - break; - case TCG_COND_GE: - tcg_out_brcond(s, TCG_COND_GT, args[1], args[3], const_args[3], args[5]); - tcg_out_jxx(s, JCC_JNE, label_next); - tcg_out_brcond(s, TCG_COND_GEU, args[0], args[2], const_args[2], args[5]); - break; - case TCG_COND_LTU: - tcg_out_brcond(s, TCG_COND_LTU, args[1], args[3], const_args[3], args[5]); - tcg_out_jxx(s, JCC_JNE, label_next); - tcg_out_brcond(s, TCG_COND_LTU, args[0], args[2], const_args[2], args[5]); - break; - case TCG_COND_LEU: - tcg_out_brcond(s, TCG_COND_LTU, args[1], args[3], const_args[3], args[5]); - tcg_out_jxx(s, JCC_JNE, label_next); - tcg_out_brcond(s, TCG_COND_LEU, args[0], args[2], const_args[2], args[5]); - break; - case TCG_COND_GTU: - tcg_out_brcond(s, TCG_COND_GTU, args[1], args[3], const_args[3], args[5]); - tcg_out_jxx(s, JCC_JNE, label_next); - tcg_out_brcond(s, TCG_COND_GTU, args[0], args[2], const_args[2], args[5]); - break; - case TCG_COND_GEU: - tcg_out_brcond(s, TCG_COND_GTU, args[1], args[3], const_args[3], args[5]); - tcg_out_jxx(s, JCC_JNE, label_next); - tcg_out_brcond(s, TCG_COND_GEU, args[0], args[2], const_args[2], args[5]); - break; - default: - tcg_abort(); - } - tcg_out_label(s, label_next, (tcg_target_long)s->code_ptr); -} - -#if defined(CONFIG_SOFTMMU) - -#include "../../softmmu_defs.h" - -static void *qemu_ld_helpers[4] = { - __ldb_mmu, - __ldw_mmu, - __ldl_mmu, - __ldq_mmu, -}; - -static void *qemu_st_helpers[4] = { - __stb_mmu, - __stw_mmu, - __stl_mmu, - __stq_mmu, -}; -#endif - -#ifndef CONFIG_USER_ONLY -#define GUEST_BASE 0 -#endif - -/* XXX: qemu_ld and qemu_st could be modified to clobber only EDX and - EAX. It will be useful once fixed registers globals are less - common. */ -static void tcg_out_qemu_ld(TCGContext *s, const TCGArg *args, - int opc) -{ - int addr_reg, data_reg, data_reg2, r0, r1, mem_index, s_bits, bswap; -#if defined(CONFIG_SOFTMMU) - uint8_t *label1_ptr, *label2_ptr; -#endif -#if TARGET_LONG_BITS == 64 -#if defined(CONFIG_SOFTMMU) - uint8_t *label3_ptr; -#endif - int addr_reg2; -#endif - - data_reg = *args++; - if (opc == 3) - data_reg2 = *args++; - else - data_reg2 = 0; - addr_reg = *args++; -#if TARGET_LONG_BITS == 64 - addr_reg2 = *args++; -#endif - mem_index = *args; - s_bits = opc & 3; - - r0 = TCG_REG_EAX; - r1 = TCG_REG_EDX; - -#if defined(CONFIG_SOFTMMU) - tcg_out_mov(s, r1, addr_reg); - - tcg_out_mov(s, r0, addr_reg); - - tcg_out_modrm(s, 0xc1, 5, r1); /* shr $x, r1 */ - tcg_out8(s, TARGET_PAGE_BITS - CPU_TLB_ENTRY_BITS); - - tcg_out_modrm(s, 0x81, 4, r0); /* andl $x, r0 */ - tcg_out32(s, TARGET_PAGE_MASK | ((1 << s_bits) - 1)); - - tcg_out_modrm(s, 0x81, 4, r1); /* andl $x, r1 */ - tcg_out32(s, (CPU_TLB_SIZE - 1) << CPU_TLB_ENTRY_BITS); - - tcg_out_opc(s, 0x8d); /* lea offset(r1, %ebp), r1 */ - tcg_out8(s, 0x80 | (r1 << 3) | 0x04); - tcg_out8(s, (5 << 3) | r1); - tcg_out32(s, offsetof(CPUState, tlb_table[mem_index][0].addr_read)); - - /* cmp 0(r1), r0 */ - tcg_out_modrm_offset(s, 0x3b, r0, r1, 0); - - tcg_out_mov(s, r0, addr_reg); - -#if TARGET_LONG_BITS == 32 - /* je label1 */ - tcg_out8(s, 0x70 + JCC_JE); - label1_ptr = s->code_ptr; - s->code_ptr++; -#else - /* jne label3 */ - tcg_out8(s, 0x70 + JCC_JNE); - label3_ptr = s->code_ptr; - s->code_ptr++; - - /* cmp 4(r1), addr_reg2 */ - tcg_out_modrm_offset(s, 0x3b, addr_reg2, r1, 4); - - /* je label1 */ - tcg_out8(s, 0x70 + JCC_JE); - label1_ptr = s->code_ptr; - s->code_ptr++; - - /* label3: */ - *label3_ptr = s->code_ptr - label3_ptr - 1; -#endif - - /* XXX: move that code at the end of the TB */ -#if TARGET_LONG_BITS == 32 - tcg_out_movi(s, TCG_TYPE_I32, TCG_REG_EDX, mem_index); -#else - tcg_out_mov(s, TCG_REG_EDX, addr_reg2); - tcg_out_movi(s, TCG_TYPE_I32, TCG_REG_ECX, mem_index); -#endif - tcg_out8(s, 0xe8); - tcg_out32(s, (tcg_target_long)qemu_ld_helpers[s_bits] - - (tcg_target_long)s->code_ptr - 4); - - switch(opc) { - case 0 | 4: - /* movsbl */ - tcg_out_modrm(s, 0xbe | P_EXT, data_reg, TCG_REG_EAX); - break; - case 1 | 4: - /* movswl */ - tcg_out_modrm(s, 0xbf | P_EXT, data_reg, TCG_REG_EAX); - break; - case 0: - /* movzbl */ - tcg_out_modrm(s, 0xb6 | P_EXT, data_reg, TCG_REG_EAX); - break; - case 1: - /* movzwl */ - tcg_out_modrm(s, 0xb7 | P_EXT, data_reg, TCG_REG_EAX); - break; - case 2: - default: - tcg_out_mov(s, data_reg, TCG_REG_EAX); - break; - case 3: - if (data_reg == TCG_REG_EDX) { - tcg_out_opc(s, 0x90 + TCG_REG_EDX); /* xchg %edx, %eax */ - tcg_out_mov(s, data_reg2, TCG_REG_EAX); - } else { - tcg_out_mov(s, data_reg, TCG_REG_EAX); - tcg_out_mov(s, data_reg2, TCG_REG_EDX); - } - break; - } - - /* jmp label2 */ - tcg_out8(s, 0xeb); - label2_ptr = s->code_ptr; - s->code_ptr++; - - /* label1: */ - *label1_ptr = s->code_ptr - label1_ptr - 1; - - /* add x(r1), r0 */ - tcg_out_modrm_offset(s, 0x03, r0, r1, offsetof(CPUTLBEntry, addend) - - offsetof(CPUTLBEntry, addr_read)); -#else - r0 = addr_reg; -#endif - -#ifdef TARGET_WORDS_BIGENDIAN - bswap = 1; -#else - bswap = 0; -#endif - switch(opc) { - case 0: - /* movzbl */ - tcg_out_modrm_offset(s, 0xb6 | P_EXT, data_reg, r0, GUEST_BASE); - break; - case 0 | 4: - /* movsbl */ - tcg_out_modrm_offset(s, 0xbe | P_EXT, data_reg, r0, GUEST_BASE); - break; - case 1: - /* movzwl */ - tcg_out_modrm_offset(s, 0xb7 | P_EXT, data_reg, r0, GUEST_BASE); - if (bswap) { - /* rolw $8, data_reg */ - tcg_out8(s, 0x66); - tcg_out_modrm(s, 0xc1, 0, data_reg); - tcg_out8(s, 8); - } - break; - case 1 | 4: - /* movswl */ - tcg_out_modrm_offset(s, 0xbf | P_EXT, data_reg, r0, GUEST_BASE); - if (bswap) { - /* rolw $8, data_reg */ - tcg_out8(s, 0x66); - tcg_out_modrm(s, 0xc1, 0, data_reg); - tcg_out8(s, 8); - - /* movswl data_reg, data_reg */ - tcg_out_modrm(s, 0xbf | P_EXT, data_reg, data_reg); - } - break; - case 2: - /* movl (r0), data_reg */ - tcg_out_modrm_offset(s, 0x8b, data_reg, r0, GUEST_BASE); - if (bswap) { - /* bswap */ - tcg_out_opc(s, (0xc8 + data_reg) | P_EXT); - } - break; - case 3: - /* XXX: could be nicer */ - if (r0 == data_reg) { - r1 = TCG_REG_EDX; - if (r1 == data_reg) - r1 = TCG_REG_EAX; - tcg_out_mov(s, r1, r0); - r0 = r1; - } - if (!bswap) { - tcg_out_modrm_offset(s, 0x8b, data_reg, r0, GUEST_BASE); - tcg_out_modrm_offset(s, 0x8b, data_reg2, r0, GUEST_BASE + 4); - } else { - tcg_out_modrm_offset(s, 0x8b, data_reg, r0, GUEST_BASE + 4); - tcg_out_opc(s, (0xc8 + data_reg) | P_EXT); - - tcg_out_modrm_offset(s, 0x8b, data_reg2, r0, GUEST_BASE); - /* bswap */ - tcg_out_opc(s, (0xc8 + data_reg2) | P_EXT); - } - break; - default: - tcg_abort(); - } - -#if defined(CONFIG_SOFTMMU) - /* label2: */ - *label2_ptr = s->code_ptr - label2_ptr - 1; -#endif -} - - -static void tcg_out_qemu_st(TCGContext *s, const TCGArg *args, - int opc) -{ - int addr_reg, data_reg, data_reg2, r0, r1, mem_index, s_bits, bswap; -#if defined(CONFIG_SOFTMMU) - uint8_t *label1_ptr, *label2_ptr; -#endif -#if TARGET_LONG_BITS == 64 -#if defined(CONFIG_SOFTMMU) - uint8_t *label3_ptr; -#endif - int addr_reg2; -#endif - - data_reg = *args++; - if (opc == 3) - data_reg2 = *args++; - else - data_reg2 = 0; - addr_reg = *args++; -#if TARGET_LONG_BITS == 64 - addr_reg2 = *args++; -#endif - mem_index = *args; - - s_bits = opc; - - r0 = TCG_REG_EAX; - r1 = TCG_REG_EDX; - -#if defined(CONFIG_SOFTMMU) - tcg_out_mov(s, r1, addr_reg); - - tcg_out_mov(s, r0, addr_reg); - - tcg_out_modrm(s, 0xc1, 5, r1); /* shr $x, r1 */ - tcg_out8(s, TARGET_PAGE_BITS - CPU_TLB_ENTRY_BITS); - - tcg_out_modrm(s, 0x81, 4, r0); /* andl $x, r0 */ - tcg_out32(s, TARGET_PAGE_MASK | ((1 << s_bits) - 1)); - - tcg_out_modrm(s, 0x81, 4, r1); /* andl $x, r1 */ - tcg_out32(s, (CPU_TLB_SIZE - 1) << CPU_TLB_ENTRY_BITS); - - tcg_out_opc(s, 0x8d); /* lea offset(r1, %ebp), r1 */ - tcg_out8(s, 0x80 | (r1 << 3) | 0x04); - tcg_out8(s, (5 << 3) | r1); - tcg_out32(s, offsetof(CPUState, tlb_table[mem_index][0].addr_write)); - - /* cmp 0(r1), r0 */ - tcg_out_modrm_offset(s, 0x3b, r0, r1, 0); - - tcg_out_mov(s, r0, addr_reg); - -#if TARGET_LONG_BITS == 32 - /* je label1 */ - tcg_out8(s, 0x70 + JCC_JE); - label1_ptr = s->code_ptr; - s->code_ptr++; -#else - /* jne label3 */ - tcg_out8(s, 0x70 + JCC_JNE); - label3_ptr = s->code_ptr; - s->code_ptr++; - - /* cmp 4(r1), addr_reg2 */ - tcg_out_modrm_offset(s, 0x3b, addr_reg2, r1, 4); - - /* je label1 */ - tcg_out8(s, 0x70 + JCC_JE); - label1_ptr = s->code_ptr; - s->code_ptr++; - - /* label3: */ - *label3_ptr = s->code_ptr - label3_ptr - 1; -#endif - - /* XXX: move that code at the end of the TB */ -#if TARGET_LONG_BITS == 32 - if (opc == 3) { - tcg_out_mov(s, TCG_REG_EDX, data_reg); - tcg_out_mov(s, TCG_REG_ECX, data_reg2); - tcg_out8(s, 0x6a); /* push Ib */ - tcg_out8(s, mem_index); - tcg_out8(s, 0xe8); - tcg_out32(s, (tcg_target_long)qemu_st_helpers[s_bits] - - (tcg_target_long)s->code_ptr - 4); - tcg_out_addi(s, TCG_REG_ESP, 4); - } else { - switch(opc) { - case 0: - /* movzbl */ - tcg_out_modrm(s, 0xb6 | P_EXT, TCG_REG_EDX, data_reg); - break; - case 1: - /* movzwl */ - tcg_out_modrm(s, 0xb7 | P_EXT, TCG_REG_EDX, data_reg); - break; - case 2: - tcg_out_mov(s, TCG_REG_EDX, data_reg); - break; - } - tcg_out_movi(s, TCG_TYPE_I32, TCG_REG_ECX, mem_index); - tcg_out8(s, 0xe8); - tcg_out32(s, (tcg_target_long)qemu_st_helpers[s_bits] - - (tcg_target_long)s->code_ptr - 4); - } -#else - if (opc == 3) { - tcg_out_mov(s, TCG_REG_EDX, addr_reg2); - tcg_out8(s, 0x6a); /* push Ib */ - tcg_out8(s, mem_index); - tcg_out_opc(s, 0x50 + data_reg2); /* push */ - tcg_out_opc(s, 0x50 + data_reg); /* push */ - tcg_out8(s, 0xe8); - tcg_out32(s, (tcg_target_long)qemu_st_helpers[s_bits] - - (tcg_target_long)s->code_ptr - 4); - tcg_out_addi(s, TCG_REG_ESP, 12); - } else { - tcg_out_mov(s, TCG_REG_EDX, addr_reg2); - switch(opc) { - case 0: - /* movzbl */ - tcg_out_modrm(s, 0xb6 | P_EXT, TCG_REG_ECX, data_reg); - break; - case 1: - /* movzwl */ - tcg_out_modrm(s, 0xb7 | P_EXT, TCG_REG_ECX, data_reg); - break; - case 2: - tcg_out_mov(s, TCG_REG_ECX, data_reg); - break; - } - tcg_out8(s, 0x6a); /* push Ib */ - tcg_out8(s, mem_index); - tcg_out8(s, 0xe8); - tcg_out32(s, (tcg_target_long)qemu_st_helpers[s_bits] - - (tcg_target_long)s->code_ptr - 4); - tcg_out_addi(s, TCG_REG_ESP, 4); - } -#endif - - /* jmp label2 */ - tcg_out8(s, 0xeb); - label2_ptr = s->code_ptr; - s->code_ptr++; - - /* label1: */ - *label1_ptr = s->code_ptr - label1_ptr - 1; - - /* add x(r1), r0 */ - tcg_out_modrm_offset(s, 0x03, r0, r1, offsetof(CPUTLBEntry, addend) - - offsetof(CPUTLBEntry, addr_write)); -#else - r0 = addr_reg; -#endif - -#ifdef TARGET_WORDS_BIGENDIAN - bswap = 1; -#else - bswap = 0; -#endif - switch(opc) { - case 0: - /* movb */ - tcg_out_modrm_offset(s, 0x88, data_reg, r0, GUEST_BASE); - break; - case 1: - if (bswap) { - tcg_out_mov(s, r1, data_reg); - tcg_out8(s, 0x66); /* rolw $8, %ecx */ - tcg_out_modrm(s, 0xc1, 0, r1); - tcg_out8(s, 8); - data_reg = r1; - } - /* movw */ - tcg_out8(s, 0x66); - tcg_out_modrm_offset(s, 0x89, data_reg, r0, GUEST_BASE); - break; - case 2: - if (bswap) { - tcg_out_mov(s, r1, data_reg); - /* bswap data_reg */ - tcg_out_opc(s, (0xc8 + r1) | P_EXT); - data_reg = r1; - } - /* movl */ - tcg_out_modrm_offset(s, 0x89, data_reg, r0, GUEST_BASE); - break; - case 3: - if (bswap) { - tcg_out_mov(s, r1, data_reg2); - /* bswap data_reg */ - tcg_out_opc(s, (0xc8 + r1) | P_EXT); - tcg_out_modrm_offset(s, 0x89, r1, r0, GUEST_BASE); - tcg_out_mov(s, r1, data_reg); - /* bswap data_reg */ - tcg_out_opc(s, (0xc8 + r1) | P_EXT); - tcg_out_modrm_offset(s, 0x89, r1, r0, GUEST_BASE + 4); - } else { - tcg_out_modrm_offset(s, 0x89, data_reg, r0, GUEST_BASE); - tcg_out_modrm_offset(s, 0x89, data_reg2, r0, GUEST_BASE + 4); - } - break; - default: - tcg_abort(); - } - -#if defined(CONFIG_SOFTMMU) - /* label2: */ - *label2_ptr = s->code_ptr - label2_ptr - 1; -#endif -} - -static inline void tcg_out_op(TCGContext *s, int opc, - const TCGArg *args, const int *const_args) -{ - int c; - - switch(opc) { - case INDEX_op_exit_tb: - tcg_out_movi(s, TCG_TYPE_I32, TCG_REG_EAX, args[0]); - tcg_out8(s, 0xe9); /* jmp tb_ret_addr */ - tcg_out32(s, tb_ret_addr - s->code_ptr - 4); - break; - case INDEX_op_goto_tb: - if (s->tb_jmp_offset) { - /* direct jump method */ - tcg_out8(s, 0xe9); /* jmp im */ - s->tb_jmp_offset[args[0]] = s->code_ptr - s->code_buf; - tcg_out32(s, 0); - } else { - /* indirect jump method */ - /* jmp Ev */ - tcg_out_modrm_offset(s, 0xff, 4, -1, - (tcg_target_long)(s->tb_next + args[0])); - } - s->tb_next_offset[args[0]] = s->code_ptr - s->code_buf; - break; - case INDEX_op_call: - if (const_args[0]) { - tcg_out8(s, 0xe8); - tcg_out32(s, args[0] - (tcg_target_long)s->code_ptr - 4); - } else { - tcg_out_modrm(s, 0xff, 2, args[0]); - } - break; - case INDEX_op_jmp: - if (const_args[0]) { - tcg_out8(s, 0xe9); - tcg_out32(s, args[0] - (tcg_target_long)s->code_ptr - 4); - } else { - tcg_out_modrm(s, 0xff, 4, args[0]); - } - break; - case INDEX_op_br: - tcg_out_jxx(s, JCC_JMP, args[0]); - break; - case INDEX_op_movi_i32: - tcg_out_movi(s, TCG_TYPE_I32, args[0], args[1]); - break; - case INDEX_op_ld8u_i32: - /* movzbl */ - tcg_out_modrm_offset(s, 0xb6 | P_EXT, args[0], args[1], args[2]); - break; - case INDEX_op_ld8s_i32: - /* movsbl */ - tcg_out_modrm_offset(s, 0xbe | P_EXT, args[0], args[1], args[2]); - break; - case INDEX_op_ld16u_i32: - /* movzwl */ - tcg_out_modrm_offset(s, 0xb7 | P_EXT, args[0], args[1], args[2]); - break; - case INDEX_op_ld16s_i32: - /* movswl */ - tcg_out_modrm_offset(s, 0xbf | P_EXT, args[0], args[1], args[2]); - break; - case INDEX_op_ld_i32: - /* movl */ - tcg_out_modrm_offset(s, 0x8b, args[0], args[1], args[2]); - break; - case INDEX_op_st8_i32: - /* movb */ - tcg_out_modrm_offset(s, 0x88, args[0], args[1], args[2]); - break; - case INDEX_op_st16_i32: - /* movw */ - tcg_out8(s, 0x66); - tcg_out_modrm_offset(s, 0x89, args[0], args[1], args[2]); - break; - case INDEX_op_st_i32: - /* movl */ - tcg_out_modrm_offset(s, 0x89, args[0], args[1], args[2]); - break; - case INDEX_op_sub_i32: - c = ARITH_SUB; - goto gen_arith; - case INDEX_op_and_i32: - c = ARITH_AND; - goto gen_arith; - case INDEX_op_or_i32: - c = ARITH_OR; - goto gen_arith; - case INDEX_op_xor_i32: - c = ARITH_XOR; - goto gen_arith; - case INDEX_op_add_i32: - c = ARITH_ADD; - gen_arith: - if (const_args[2]) { - tgen_arithi(s, c, args[0], args[2], 0); - } else { - tcg_out_modrm(s, 0x01 | (c << 3), args[2], args[0]); - } - break; - case INDEX_op_mul_i32: - if (const_args[2]) { - int32_t val; - val = args[2]; - if (val == (int8_t)val) { - tcg_out_modrm(s, 0x6b, args[0], args[0]); - tcg_out8(s, val); - } else { - tcg_out_modrm(s, 0x69, args[0], args[0]); - tcg_out32(s, val); - } - } else { - tcg_out_modrm(s, 0xaf | P_EXT, args[0], args[2]); - } - break; - case INDEX_op_mulu2_i32: - tcg_out_modrm(s, 0xf7, 4, args[3]); - break; - case INDEX_op_div2_i32: - tcg_out_modrm(s, 0xf7, 7, args[4]); - break; - case INDEX_op_divu2_i32: - tcg_out_modrm(s, 0xf7, 6, args[4]); - break; - case INDEX_op_shl_i32: - c = SHIFT_SHL; - gen_shift32: - if (const_args[2]) { - if (args[2] == 1) { - tcg_out_modrm(s, 0xd1, c, args[0]); - } else { - tcg_out_modrm(s, 0xc1, c, args[0]); - tcg_out8(s, args[2]); - } - } else { - tcg_out_modrm(s, 0xd3, c, args[0]); - } - break; - case INDEX_op_shr_i32: - c = SHIFT_SHR; - goto gen_shift32; - case INDEX_op_sar_i32: - c = SHIFT_SAR; - goto gen_shift32; - case INDEX_op_rotl_i32: - c = SHIFT_ROL; - goto gen_shift32; - case INDEX_op_rotr_i32: - c = SHIFT_ROR; - goto gen_shift32; - - case INDEX_op_add2_i32: - if (const_args[4]) - tgen_arithi(s, ARITH_ADD, args[0], args[4], 1); - else - tcg_out_modrm(s, 0x01 | (ARITH_ADD << 3), args[4], args[0]); - if (const_args[5]) - tgen_arithi(s, ARITH_ADC, args[1], args[5], 1); - else - tcg_out_modrm(s, 0x01 | (ARITH_ADC << 3), args[5], args[1]); - break; - case INDEX_op_sub2_i32: - if (const_args[4]) - tgen_arithi(s, ARITH_SUB, args[0], args[4], 1); - else - tcg_out_modrm(s, 0x01 | (ARITH_SUB << 3), args[4], args[0]); - if (const_args[5]) - tgen_arithi(s, ARITH_SBB, args[1], args[5], 1); - else - tcg_out_modrm(s, 0x01 | (ARITH_SBB << 3), args[5], args[1]); - break; - case INDEX_op_brcond_i32: - tcg_out_brcond(s, args[2], args[0], args[1], const_args[1], args[3]); - break; - case INDEX_op_brcond2_i32: - tcg_out_brcond2(s, args, const_args); - break; - - case INDEX_op_bswap16_i32: - tcg_out8(s, 0x66); - tcg_out_modrm(s, 0xc1, SHIFT_ROL, args[0]); - tcg_out8(s, 8); - break; - case INDEX_op_bswap32_i32: - tcg_out_opc(s, (0xc8 + args[0]) | P_EXT); - break; - - case INDEX_op_neg_i32: - tcg_out_modrm(s, 0xf7, 3, args[0]); - break; - - case INDEX_op_not_i32: - tcg_out_modrm(s, 0xf7, 2, args[0]); - break; - - case INDEX_op_ext8s_i32: - tcg_out_modrm(s, 0xbe | P_EXT, args[0], args[1]); - break; - case INDEX_op_ext16s_i32: - tcg_out_modrm(s, 0xbf | P_EXT, args[0], args[1]); - break; - case INDEX_op_ext8u_i32: - tcg_out_modrm(s, 0xb6 | P_EXT, args[0], args[1]); - break; - case INDEX_op_ext16u_i32: - tcg_out_modrm(s, 0xb7 | P_EXT, args[0], args[1]); - break; - - case INDEX_op_qemu_ld8u: - tcg_out_qemu_ld(s, args, 0); - break; - case INDEX_op_qemu_ld8s: - tcg_out_qemu_ld(s, args, 0 | 4); - break; - case INDEX_op_qemu_ld16u: - tcg_out_qemu_ld(s, args, 1); - break; - case INDEX_op_qemu_ld16s: - tcg_out_qemu_ld(s, args, 1 | 4); - break; - case INDEX_op_qemu_ld32u: - tcg_out_qemu_ld(s, args, 2); - break; - case INDEX_op_qemu_ld64: - tcg_out_qemu_ld(s, args, 3); - break; - - case INDEX_op_qemu_st8: - tcg_out_qemu_st(s, args, 0); - break; - case INDEX_op_qemu_st16: - tcg_out_qemu_st(s, args, 1); - break; - case INDEX_op_qemu_st32: - tcg_out_qemu_st(s, args, 2); - break; - case INDEX_op_qemu_st64: - tcg_out_qemu_st(s, args, 3); - break; - - default: - tcg_abort(); - } -} - -static const TCGTargetOpDef x86_op_defs[] = { - { INDEX_op_exit_tb, { } }, - { INDEX_op_goto_tb, { } }, - { INDEX_op_call, { "ri" } }, - { INDEX_op_jmp, { "ri" } }, - { INDEX_op_br, { } }, - { INDEX_op_mov_i32, { "r", "r" } }, - { INDEX_op_movi_i32, { "r" } }, - { INDEX_op_ld8u_i32, { "r", "r" } }, - { INDEX_op_ld8s_i32, { "r", "r" } }, - { INDEX_op_ld16u_i32, { "r", "r" } }, - { INDEX_op_ld16s_i32, { "r", "r" } }, - { INDEX_op_ld_i32, { "r", "r" } }, - { INDEX_op_st8_i32, { "q", "r" } }, - { INDEX_op_st16_i32, { "r", "r" } }, - { INDEX_op_st_i32, { "r", "r" } }, - - { INDEX_op_add_i32, { "r", "0", "ri" } }, - { INDEX_op_sub_i32, { "r", "0", "ri" } }, - { INDEX_op_mul_i32, { "r", "0", "ri" } }, - { INDEX_op_mulu2_i32, { "a", "d", "a", "r" } }, - { INDEX_op_div2_i32, { "a", "d", "0", "1", "r" } }, - { INDEX_op_divu2_i32, { "a", "d", "0", "1", "r" } }, - { INDEX_op_and_i32, { "r", "0", "ri" } }, - { INDEX_op_or_i32, { "r", "0", "ri" } }, - { INDEX_op_xor_i32, { "r", "0", "ri" } }, - - { INDEX_op_shl_i32, { "r", "0", "ci" } }, - { INDEX_op_shr_i32, { "r", "0", "ci" } }, - { INDEX_op_sar_i32, { "r", "0", "ci" } }, - { INDEX_op_rotl_i32, { "r", "0", "ci" } }, - { INDEX_op_rotr_i32, { "r", "0", "ci" } }, - - { INDEX_op_brcond_i32, { "r", "ri" } }, - - { INDEX_op_add2_i32, { "r", "r", "0", "1", "ri", "ri" } }, - { INDEX_op_sub2_i32, { "r", "r", "0", "1", "ri", "ri" } }, - { INDEX_op_brcond2_i32, { "r", "r", "ri", "ri" } }, - - { INDEX_op_bswap16_i32, { "r", "0" } }, - { INDEX_op_bswap32_i32, { "r", "0" } }, - - { INDEX_op_neg_i32, { "r", "0" } }, - - { INDEX_op_not_i32, { "r", "0" } }, - - { INDEX_op_ext8s_i32, { "r", "q" } }, - { INDEX_op_ext16s_i32, { "r", "r" } }, - { INDEX_op_ext8u_i32, { "r", "q"} }, - { INDEX_op_ext16u_i32, { "r", "r"} }, - -#if TARGET_LONG_BITS == 32 - { INDEX_op_qemu_ld8u, { "r", "L" } }, - { INDEX_op_qemu_ld8s, { "r", "L" } }, - { INDEX_op_qemu_ld16u, { "r", "L" } }, - { INDEX_op_qemu_ld16s, { "r", "L" } }, - { INDEX_op_qemu_ld32u, { "r", "L" } }, - { INDEX_op_qemu_ld64, { "r", "r", "L" } }, - - { INDEX_op_qemu_st8, { "cb", "L" } }, - { INDEX_op_qemu_st16, { "L", "L" } }, - { INDEX_op_qemu_st32, { "L", "L" } }, - { INDEX_op_qemu_st64, { "L", "L", "L" } }, -#else - { INDEX_op_qemu_ld8u, { "r", "L", "L" } }, - { INDEX_op_qemu_ld8s, { "r", "L", "L" } }, - { INDEX_op_qemu_ld16u, { "r", "L", "L" } }, - { INDEX_op_qemu_ld16s, { "r", "L", "L" } }, - { INDEX_op_qemu_ld32u, { "r", "L", "L" } }, - { INDEX_op_qemu_ld64, { "r", "r", "L", "L" } }, - - { INDEX_op_qemu_st8, { "cb", "L", "L" } }, - { INDEX_op_qemu_st16, { "L", "L", "L" } }, - { INDEX_op_qemu_st32, { "L", "L", "L" } }, - { INDEX_op_qemu_st64, { "L", "L", "L", "L" } }, -#endif - { -1 }, -}; - -static int tcg_target_callee_save_regs[] = { - /* TCG_REG_EBP, */ /* currently used for the global env, so no - need to save */ - TCG_REG_EBX, - TCG_REG_ESI, - TCG_REG_EDI, -}; - -static inline void tcg_out_push(TCGContext *s, int reg) -{ - tcg_out_opc(s, 0x50 + reg); -} - -static inline void tcg_out_pop(TCGContext *s, int reg) -{ - tcg_out_opc(s, 0x58 + reg); -} - -/* Generate global QEMU prologue and epilogue code */ -void tcg_target_qemu_prologue(TCGContext *s) -{ - int i, frame_size, push_size, stack_addend; - - /* TB prologue */ - /* save all callee saved registers */ - for(i = 0; i < ARRAY_SIZE(tcg_target_callee_save_regs); i++) { - tcg_out_push(s, tcg_target_callee_save_regs[i]); - } - /* reserve some stack space */ - push_size = 4 + ARRAY_SIZE(tcg_target_callee_save_regs) * 4; - frame_size = push_size + TCG_STATIC_CALL_ARGS_SIZE; - frame_size = (frame_size + TCG_TARGET_STACK_ALIGN - 1) & - ~(TCG_TARGET_STACK_ALIGN - 1); - stack_addend = frame_size - push_size; - tcg_out_addi(s, TCG_REG_ESP, -stack_addend); - - tcg_out_modrm(s, 0xff, 4, TCG_REG_EAX); /* jmp *%eax */ - - /* TB epilogue */ - tb_ret_addr = s->code_ptr; - tcg_out_addi(s, TCG_REG_ESP, stack_addend); - for(i = ARRAY_SIZE(tcg_target_callee_save_regs) - 1; i >= 0; i--) { - tcg_out_pop(s, tcg_target_callee_save_regs[i]); - } - tcg_out8(s, 0xc3); /* ret */ -} - -void tcg_target_init(TCGContext *s) -{ - /* fail safe */ - if ((1 << CPU_TLB_ENTRY_BITS) != sizeof(CPUTLBEntry)) - tcg_abort(); - - tcg_regset_set32(tcg_target_available_regs[TCG_TYPE_I32], 0, 0xff); - tcg_regset_set32(tcg_target_call_clobber_regs, 0, - (1 << TCG_REG_EAX) | - (1 << TCG_REG_EDX) | - (1 << TCG_REG_ECX)); - - tcg_regset_clear(s->reserved_regs); - tcg_regset_set_reg(s->reserved_regs, TCG_REG_ESP); - - tcg_add_target_add_op_defs(x86_op_defs); -} diff --git a/qemu/qemu-git/tcg/i386/.svn/text-base/tcg-target.h.svn-base b/qemu/qemu-git/tcg/i386/.svn/text-base/tcg-target.h.svn-base deleted file mode 100644 index 69227c3..0000000 --- a/qemu/qemu-git/tcg/i386/.svn/text-base/tcg-target.h.svn-base +++ /dev/null @@ -1,67 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2008 Fabrice Bellard - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ -#define TCG_TARGET_I386 1 - -#define TCG_TARGET_REG_BITS 32 -//#define TCG_TARGET_WORDS_BIGENDIAN - -#define TCG_TARGET_NB_REGS 8 - -enum { - TCG_REG_EAX = 0, - TCG_REG_ECX, - TCG_REG_EDX, - TCG_REG_EBX, - TCG_REG_ESP, - TCG_REG_EBP, - TCG_REG_ESI, - TCG_REG_EDI, -}; - -/* used for function call generation */ -#define TCG_REG_CALL_STACK TCG_REG_ESP -#define TCG_TARGET_STACK_ALIGN 16 -#define TCG_TARGET_CALL_STACK_OFFSET 0 - -/* optional instructions */ -#define TCG_TARGET_HAS_bswap16_i32 -#define TCG_TARGET_HAS_bswap32_i32 -#define TCG_TARGET_HAS_neg_i32 -#define TCG_TARGET_HAS_not_i32 -#define TCG_TARGET_HAS_ext8s_i32 -#define TCG_TARGET_HAS_ext16s_i32 -#define TCG_TARGET_HAS_rot_i32 -#define TCG_TARGET_HAS_ext8u_i32 -#define TCG_TARGET_HAS_ext16u_i32 - -#define TCG_TARGET_HAS_GUEST_BASE - -/* Note: must be synced with dyngen-exec.h */ -#define TCG_AREG0 TCG_REG_EBP -#define TCG_AREG1 TCG_REG_EBX -#define TCG_AREG2 TCG_REG_ESI - -static inline void flush_icache_range(unsigned long start, unsigned long stop) -{ -} diff --git a/qemu/qemu-git/tcg/mips/.svn/all-wcprops b/qemu/qemu-git/tcg/mips/.svn/all-wcprops deleted file mode 100644 index e129c1c..0000000 --- a/qemu/qemu-git/tcg/mips/.svn/all-wcprops +++ /dev/null @@ -1,17 +0,0 @@ -K 25 -svn:wc:ra_dav:version-url -V 48 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/mips -END -tcg-target.c -K 25 -svn:wc:ra_dav:version-url -V 61 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/mips/tcg-target.c -END -tcg-target.h -K 25 -svn:wc:ra_dav:version-url -V 61 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/mips/tcg-target.h -END diff --git a/qemu/qemu-git/tcg/mips/.svn/entries b/qemu/qemu-git/tcg/mips/.svn/entries deleted file mode 100644 index 245feb8..0000000 --- a/qemu/qemu-git/tcg/mips/.svn/entries +++ /dev/null @@ -1,96 +0,0 @@ -10 - -dir -11 -http://svn.code.sf.net/p/x49gp/code/qemu/qemu-git/tcg/mips -http://svn.code.sf.net/p/x49gp/code - - - -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - -481df3bd-3408-496c-b7de-451e46197bb5 - -tcg-target.c -file - - - - -2013-08-23T00:54:47.000000Z -c32ff2c4b3b3b43bf7ca41220e9fbfaf -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -40459 - -tcg-target.h -file - - - - -2013-08-23T00:54:47.000000Z -c18f6e092964f5d0f33a12a38e7cf4e8 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -3067 - diff --git a/qemu/qemu-git/tcg/mips/.svn/text-base/tcg-target.c.svn-base b/qemu/qemu-git/tcg/mips/.svn/text-base/tcg-target.c.svn-base deleted file mode 100644 index 8fcb5c9..0000000 --- a/qemu/qemu-git/tcg/mips/.svn/text-base/tcg-target.c.svn-base +++ /dev/null @@ -1,1342 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2008-2009 Arnaud Patard - * Copyright (c) 2009 Aurelien Jarno - * Based on i386/tcg-target.c - Copyright (c) 2008 Fabrice Bellard - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ - -#if defined(TCG_TARGET_WORDS_BIGENDIAN) == defined(TARGET_WORDS_BIGENDIAN) -# define TCG_NEED_BSWAP 0 -#else -# define TCG_NEED_BSWAP 1 -#endif - -#ifndef NDEBUG -static const char * const tcg_target_reg_names[TCG_TARGET_NB_REGS] = { - "zero", - "at", - "v0", - "v1", - "a0", - "a1", - "a2", - "a3", - "t0", - "t1", - "t2", - "t3", - "t4", - "t5", - "t6", - "t7", - "s0", - "s1", - "s2", - "s3", - "s4", - "s5", - "s6", - "s7", - "t8", - "t9", - "k0", - "k1", - "gp", - "sp", - "fp", - "ra", -}; -#endif - -/* check if we really need so many registers :P */ -static const int tcg_target_reg_alloc_order[] = { - TCG_REG_S0, - TCG_REG_S1, - TCG_REG_S2, - TCG_REG_S3, - TCG_REG_S4, - TCG_REG_S5, - TCG_REG_S6, - TCG_REG_S7, - TCG_REG_T1, - TCG_REG_T2, - TCG_REG_T3, - TCG_REG_T4, - TCG_REG_T5, - TCG_REG_T6, - TCG_REG_T7, - TCG_REG_T8, - TCG_REG_T9, - TCG_REG_A0, - TCG_REG_A1, - TCG_REG_A2, - TCG_REG_A3, - TCG_REG_V0, - TCG_REG_V1 -}; - -static const int tcg_target_call_iarg_regs[4] = { - TCG_REG_A0, - TCG_REG_A1, - TCG_REG_A2, - TCG_REG_A3 -}; - -static const int tcg_target_call_oarg_regs[2] = { - TCG_REG_V0, - TCG_REG_V1 -}; - -static uint8_t *tb_ret_addr; - -static inline uint32_t reloc_lo16_val (void *pc, tcg_target_long target) -{ - return target & 0xffff; -} - -static inline void reloc_lo16 (void *pc, tcg_target_long target) -{ - *(uint32_t *) pc = (*(uint32_t *) pc & ~0xffff) - | reloc_lo16_val(pc, target); -} - -static inline uint32_t reloc_hi16_val (void *pc, tcg_target_long target) -{ - return (target >> 16) & 0xffff; -} - -static inline void reloc_hi16 (void *pc, tcg_target_long target) -{ - *(uint32_t *) pc = (*(uint32_t *) pc & ~0xffff) - | reloc_hi16_val(pc, target); -} - -static inline uint32_t reloc_pc16_val (void *pc, tcg_target_long target) -{ - int32_t disp; - - disp = target - (tcg_target_long) pc - 4; - if (disp != (disp << 14) >> 14) { - tcg_abort (); - } - - return (disp >> 2) & 0xffff; -} - -static inline void reloc_pc16 (void *pc, tcg_target_long target) -{ - *(uint32_t *) pc = (*(uint32_t *) pc & ~0xffff) - | reloc_pc16_val(pc, target); -} - -static inline uint32_t reloc_26_val (void *pc, tcg_target_long target) -{ - if ((((tcg_target_long)pc + 4) & 0xf0000000) != (target & 0xf0000000)) { - tcg_abort (); - } - - return (target >> 2) & 0x3ffffff; -} - -static inline void reloc_pc26 (void *pc, tcg_target_long target) -{ - *(uint32_t *) pc = (*(uint32_t *) pc & ~0x3ffffff) - | reloc_26_val(pc, target); -} - -static void patch_reloc(uint8_t *code_ptr, int type, - tcg_target_long value, tcg_target_long addend) -{ - value += addend; - switch(type) { - case R_MIPS_LO16: - reloc_lo16(code_ptr, value); - break; - case R_MIPS_HI16: - reloc_hi16(code_ptr, value); - break; - case R_MIPS_PC16: - reloc_pc16(code_ptr, value); - break; - case R_MIPS_26: - reloc_pc26(code_ptr, value); - break; - default: - tcg_abort(); - } -} - -/* maximum number of register used for input function arguments */ -static inline int tcg_target_get_call_iarg_regs_count(int flags) -{ - return 4; -} - -/* parse target specific constraints */ -static int target_parse_constraint(TCGArgConstraint *ct, const char **pct_str) -{ - const char *ct_str; - - ct_str = *pct_str; - switch(ct_str[0]) { - case 'r': - ct->ct |= TCG_CT_REG; - tcg_regset_set(ct->u.regs, 0xffffffff); - break; - case 'C': - ct->ct |= TCG_CT_REG; - tcg_regset_clear(ct->u.regs); - tcg_regset_set_reg(ct->u.regs, TCG_REG_T9); - break; - case 'L': /* qemu_ld output arg constraint */ - ct->ct |= TCG_CT_REG; - tcg_regset_set(ct->u.regs, 0xffffffff); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_V0); - break; - case 'l': /* qemu_ld input arg constraint */ - ct->ct |= TCG_CT_REG; - tcg_regset_set(ct->u.regs, 0xffffffff); -#if defined(CONFIG_SOFTMMU) - tcg_regset_reset_reg(ct->u.regs, TCG_REG_A0); -#endif - break; - case 'S': /* qemu_st constraint */ - ct->ct |= TCG_CT_REG; - tcg_regset_set(ct->u.regs, 0xffffffff); -#if defined(CONFIG_SOFTMMU) - tcg_regset_reset_reg(ct->u.regs, TCG_REG_A0); -# if TARGET_LONG_BITS == 64 - tcg_regset_reset_reg(ct->u.regs, TCG_REG_A1); -# endif - tcg_regset_reset_reg(ct->u.regs, TCG_REG_A2); -#endif - break; - case 'I': - ct->ct |= TCG_CT_CONST_U16; - break; - case 'J': - ct->ct |= TCG_CT_CONST_S16; - break; - case 'Z': - /* We are cheating a bit here, using the fact that the register - ZERO is also the register number 0. Hence there is no need - to check for const_args in each instruction. */ - ct->ct |= TCG_CT_CONST_ZERO; - break; - default: - return -1; - } - ct_str++; - *pct_str = ct_str; - return 0; -} - -/* test if a constant matches the constraint */ -static inline int tcg_target_const_match(tcg_target_long val, - const TCGArgConstraint *arg_ct) -{ - int ct; - ct = arg_ct->ct; - if (ct & TCG_CT_CONST) - return 1; - else if ((ct & TCG_CT_CONST_ZERO) && val == 0) - return 1; - else if ((ct & TCG_CT_CONST_U16) && val == (uint16_t)val) - return 1; - else if ((ct & TCG_CT_CONST_S16) && val == (int16_t)val) - return 1; - else - return 0; -} - -/* instruction opcodes */ -enum { - OPC_SPECIAL = 0x00 << 26, - OPC_BEQ = 0x04 << 26, - OPC_BNE = 0x05 << 26, - OPC_ADDIU = 0x09 << 26, - OPC_ANDI = 0x0C << 26, - OPC_ORI = 0x0D << 26, - OPC_XORI = 0x0E << 26, - OPC_LUI = 0x0F << 26, - OPC_LB = 0x20 << 26, - OPC_LH = 0x21 << 26, - OPC_LW = 0x23 << 26, - OPC_LBU = 0x24 << 26, - OPC_LHU = 0x25 << 26, - OPC_LWU = 0x27 << 26, - OPC_SB = 0x28 << 26, - OPC_SH = 0x29 << 26, - OPC_SW = 0x2B << 26, - OPC_SLL = OPC_SPECIAL | 0x00, - OPC_SRL = OPC_SPECIAL | 0x02, - OPC_SRA = OPC_SPECIAL | 0x03, - OPC_SLLV = OPC_SPECIAL | 0x04, - OPC_SRLV = OPC_SPECIAL | 0x06, - OPC_SRAV = OPC_SPECIAL | 0x07, - OPC_JR = OPC_SPECIAL | 0x08, - OPC_JALR = OPC_SPECIAL | 0x09, - OPC_MFHI = OPC_SPECIAL | 0x10, - OPC_MFLO = OPC_SPECIAL | 0x12, - OPC_MULT = OPC_SPECIAL | 0x18, - OPC_MULTU = OPC_SPECIAL | 0x19, - OPC_DIV = OPC_SPECIAL | 0x1A, - OPC_DIVU = OPC_SPECIAL | 0x1B, - OPC_ADDU = OPC_SPECIAL | 0x21, - OPC_SUBU = OPC_SPECIAL | 0x23, - OPC_AND = OPC_SPECIAL | 0x24, - OPC_OR = OPC_SPECIAL | 0x25, - OPC_XOR = OPC_SPECIAL | 0x26, - OPC_NOR = OPC_SPECIAL | 0x27, - OPC_SLT = OPC_SPECIAL | 0x2A, - OPC_SLTU = OPC_SPECIAL | 0x2B, -}; - -/* - * Type reg - */ -static inline void tcg_out_opc_reg(TCGContext *s, int opc, int rd, int rs, int rt) -{ - int32_t inst; - - inst = opc; - inst |= (rs & 0x1F) << 21; - inst |= (rt & 0x1F) << 16; - inst |= (rd & 0x1F) << 11; - tcg_out32(s, inst); -} - -/* - * Type immediate - */ -static inline void tcg_out_opc_imm(TCGContext *s, int opc, int rt, int rs, int imm) -{ - int32_t inst; - - inst = opc; - inst |= (rs & 0x1F) << 21; - inst |= (rt & 0x1F) << 16; - inst |= (imm & 0xffff); - tcg_out32(s, inst); -} - -/* - * Type sa - */ -static inline void tcg_out_opc_sa(TCGContext *s, int opc, int rd, int rt, int sa) -{ - int32_t inst; - - inst = opc; - inst |= (rt & 0x1F) << 16; - inst |= (rd & 0x1F) << 11; - inst |= (sa & 0x1F) << 6; - tcg_out32(s, inst); - -} - -static inline void tcg_out_nop(TCGContext *s) -{ - tcg_out32(s, 0); -} - -static inline void tcg_out_mov(TCGContext *s, int ret, int arg) -{ - tcg_out_opc_reg(s, OPC_ADDU, ret, arg, TCG_REG_ZERO); -} - -static inline void tcg_out_movi(TCGContext *s, TCGType type, - int reg, int32_t arg) -{ - if (arg == (int16_t)arg) { - tcg_out_opc_imm(s, OPC_ADDIU, reg, TCG_REG_ZERO, arg); - } else if (arg == (uint16_t)arg) { - tcg_out_opc_imm(s, OPC_ORI, reg, TCG_REG_ZERO, arg); - } else { - tcg_out_opc_imm(s, OPC_LUI, reg, 0, arg >> 16); - tcg_out_opc_imm(s, OPC_ORI, reg, reg, arg & 0xffff); - } -} - -static inline void tcg_out_bswap16(TCGContext *s, int ret, int arg) -{ - /* ret and arg can't be register at */ - if (ret == TCG_REG_AT || arg == TCG_REG_AT) { - tcg_abort(); - } - - tcg_out_opc_sa(s, OPC_SRL, TCG_REG_AT, arg, 8); - tcg_out_opc_imm(s, OPC_ANDI, TCG_REG_AT, TCG_REG_AT, 0x00ff); - - tcg_out_opc_sa(s, OPC_SLL, ret, arg, 8); - tcg_out_opc_imm(s, OPC_ANDI, ret, ret, 0xff00); - tcg_out_opc_reg(s, OPC_OR, ret, ret, TCG_REG_AT); -} - -static inline void tcg_out_bswap16s(TCGContext *s, int ret, int arg) -{ - /* ret and arg can't be register at */ - if (ret == TCG_REG_AT || arg == TCG_REG_AT) { - tcg_abort(); - } - - tcg_out_opc_sa(s, OPC_SRL, TCG_REG_AT, arg, 8); - tcg_out_opc_imm(s, OPC_ANDI, TCG_REG_AT, TCG_REG_AT, 0xff); - - tcg_out_opc_sa(s, OPC_SLL, ret, arg, 24); - tcg_out_opc_sa(s, OPC_SRA, ret, ret, 16); - tcg_out_opc_reg(s, OPC_OR, ret, ret, TCG_REG_AT); -} - -static inline void tcg_out_bswap32(TCGContext *s, int ret, int arg) -{ - /* ret and arg must be different and can't be register at */ - if (ret == arg || ret == TCG_REG_AT || arg == TCG_REG_AT) { - tcg_abort(); - } - - tcg_out_opc_sa(s, OPC_SLL, ret, arg, 24); - - tcg_out_opc_sa(s, OPC_SRL, TCG_REG_AT, arg, 24); - tcg_out_opc_reg(s, OPC_OR, ret, ret, TCG_REG_AT); - - tcg_out_opc_imm(s, OPC_ANDI, TCG_REG_AT, arg, 0xff00); - tcg_out_opc_sa(s, OPC_SLL, TCG_REG_AT, TCG_REG_AT, 8); - tcg_out_opc_reg(s, OPC_OR, ret, ret, TCG_REG_AT); - - tcg_out_opc_sa(s, OPC_SRL, TCG_REG_AT, arg, 8); - tcg_out_opc_imm(s, OPC_ANDI, TCG_REG_AT, TCG_REG_AT, 0xff00); - tcg_out_opc_reg(s, OPC_OR, ret, ret, TCG_REG_AT); -} - -static inline void tcg_out_ldst(TCGContext *s, int opc, int arg, - int arg1, tcg_target_long arg2) -{ - if (arg2 == (int16_t) arg2) { - tcg_out_opc_imm(s, opc, arg, arg1, arg2); - } else { - tcg_out_movi(s, TCG_TYPE_PTR, TCG_REG_AT, arg2); - tcg_out_opc_reg(s, OPC_ADDU, TCG_REG_AT, TCG_REG_AT, arg1); - tcg_out_opc_imm(s, opc, arg, TCG_REG_AT, 0); - } -} - -static inline void tcg_out_ld(TCGContext *s, TCGType type, int arg, - int arg1, tcg_target_long arg2) -{ - tcg_out_ldst(s, OPC_LW, arg, arg1, arg2); -} - -static inline void tcg_out_st(TCGContext *s, TCGType type, int arg, - int arg1, tcg_target_long arg2) -{ - tcg_out_ldst(s, OPC_SW, arg, arg1, arg2); -} - -static inline void tcg_out_addi(TCGContext *s, int reg, tcg_target_long val) -{ - if (val == (int16_t)val) { - tcg_out_opc_imm(s, OPC_ADDIU, reg, reg, val); - } else { - tcg_out_movi(s, TCG_TYPE_PTR, TCG_REG_AT, val); - tcg_out_opc_reg(s, OPC_ADDU, reg, reg, TCG_REG_AT); - } -} - -static void tcg_out_brcond(TCGContext *s, int cond, int arg1, - int arg2, int label_index) -{ - TCGLabel *l = &s->labels[label_index]; - - switch (cond) { - case TCG_COND_EQ: - tcg_out_opc_imm(s, OPC_BEQ, arg1, arg2, 0); - break; - case TCG_COND_NE: - tcg_out_opc_imm(s, OPC_BNE, arg1, arg2, 0); - break; - case TCG_COND_LT: - tcg_out_opc_reg(s, OPC_SLT, TCG_REG_AT, arg1, arg2); - tcg_out_opc_imm(s, OPC_BNE, TCG_REG_AT, TCG_REG_ZERO, 0); - break; - case TCG_COND_LTU: - tcg_out_opc_reg(s, OPC_SLTU, TCG_REG_AT, arg1, arg2); - tcg_out_opc_imm(s, OPC_BNE, TCG_REG_AT, TCG_REG_ZERO, 0); - break; - case TCG_COND_GE: - tcg_out_opc_reg(s, OPC_SLT, TCG_REG_AT, arg1, arg2); - tcg_out_opc_imm(s, OPC_BEQ, TCG_REG_AT, TCG_REG_ZERO, 0); - break; - case TCG_COND_GEU: - tcg_out_opc_reg(s, OPC_SLTU, TCG_REG_AT, arg1, arg2); - tcg_out_opc_imm(s, OPC_BEQ, TCG_REG_AT, TCG_REG_ZERO, 0); - break; - case TCG_COND_LE: - tcg_out_opc_reg(s, OPC_SLT, TCG_REG_AT, arg2, arg1); - tcg_out_opc_imm(s, OPC_BEQ, TCG_REG_AT, TCG_REG_ZERO, 0); - break; - case TCG_COND_LEU: - tcg_out_opc_reg(s, OPC_SLTU, TCG_REG_AT, arg2, arg1); - tcg_out_opc_imm(s, OPC_BEQ, TCG_REG_AT, TCG_REG_ZERO, 0); - break; - case TCG_COND_GT: - tcg_out_opc_reg(s, OPC_SLT, TCG_REG_AT, arg2, arg1); - tcg_out_opc_imm(s, OPC_BNE, TCG_REG_AT, TCG_REG_ZERO, 0); - break; - case TCG_COND_GTU: - tcg_out_opc_reg(s, OPC_SLTU, TCG_REG_AT, arg2, arg1); - tcg_out_opc_imm(s, OPC_BNE, TCG_REG_AT, TCG_REG_ZERO, 0); - break; - default: - tcg_abort(); - break; - } - if (l->has_value) { - reloc_pc16(s->code_ptr - 4, l->u.value); - } else { - tcg_out_reloc(s, s->code_ptr - 4, R_MIPS_PC16, label_index, 0); - } - tcg_out_nop(s); -} - -/* XXX: we implement it at the target level to avoid having to - handle cross basic blocks temporaries */ -static void tcg_out_brcond2(TCGContext *s, int cond, int arg1, - int arg2, int arg3, int arg4, int label_index) -{ - void *label_ptr; - - switch(cond) { - case TCG_COND_NE: - tcg_out_brcond(s, TCG_COND_NE, arg2, arg4, label_index); - tcg_out_brcond(s, TCG_COND_NE, arg1, arg3, label_index); - return; - case TCG_COND_EQ: - break; - case TCG_COND_LT: - case TCG_COND_LE: - tcg_out_brcond(s, TCG_COND_LT, arg2, arg4, label_index); - break; - case TCG_COND_GT: - case TCG_COND_GE: - tcg_out_brcond(s, TCG_COND_GT, arg2, arg4, label_index); - break; - case TCG_COND_LTU: - case TCG_COND_LEU: - tcg_out_brcond(s, TCG_COND_LTU, arg2, arg4, label_index); - break; - case TCG_COND_GTU: - case TCG_COND_GEU: - tcg_out_brcond(s, TCG_COND_GTU, arg2, arg4, label_index); - break; - default: - tcg_abort(); - } - - label_ptr = s->code_ptr; - tcg_out_opc_imm(s, OPC_BNE, arg2, arg4, 0); - tcg_out_nop(s); - - switch(cond) { - case TCG_COND_EQ: - tcg_out_brcond(s, TCG_COND_EQ, arg1, arg3, label_index); - break; - case TCG_COND_LT: - case TCG_COND_LTU: - tcg_out_brcond(s, TCG_COND_LTU, arg1, arg3, label_index); - break; - case TCG_COND_LE: - case TCG_COND_LEU: - tcg_out_brcond(s, TCG_COND_LEU, arg1, arg3, label_index); - break; - case TCG_COND_GT: - case TCG_COND_GTU: - tcg_out_brcond(s, TCG_COND_GTU, arg1, arg3, label_index); - break; - case TCG_COND_GE: - case TCG_COND_GEU: - tcg_out_brcond(s, TCG_COND_GEU, arg1, arg3, label_index); - break; - default: - tcg_abort(); - } - - reloc_pc16(label_ptr, (tcg_target_long) s->code_ptr); -} - -#if defined(CONFIG_SOFTMMU) - -#include "../../softmmu_defs.h" - -static void *qemu_ld_helpers[4] = { - __ldb_mmu, - __ldw_mmu, - __ldl_mmu, - __ldq_mmu, -}; - -static void *qemu_st_helpers[4] = { - __stb_mmu, - __stw_mmu, - __stl_mmu, - __stq_mmu, -}; -#endif - -static void tcg_out_qemu_ld(TCGContext *s, const TCGArg *args, - int opc) -{ - int addr_regl, addr_reg1, addr_meml; - int data_regl, data_regh, data_reg1, data_reg2; - int mem_index, s_bits; -#if defined(CONFIG_SOFTMMU) - void *label1_ptr, *label2_ptr; - int sp_args; -#endif -#if TARGET_LONG_BITS == 64 -# if defined(CONFIG_SOFTMMU) - uint8_t *label3_ptr; -# endif - int addr_regh, addr_reg2, addr_memh; -#endif - data_regl = *args++; - if (opc == 3) - data_regh = *args++; - else - data_regh = 0; - addr_regl = *args++; -#if TARGET_LONG_BITS == 64 - addr_regh = *args++; -#endif - mem_index = *args; - s_bits = opc & 3; - - if (opc == 3) { -#if defined(TCG_TARGET_WORDS_BIGENDIAN) - data_reg1 = data_regh; - data_reg2 = data_regl; -#else - data_reg1 = data_regl; - data_reg2 = data_regh; -#endif - } else { - data_reg1 = data_regl; - data_reg2 = 0; - } -#if TARGET_LONG_BITS == 64 -# if defined(TCG_TARGET_WORDS_BIGENDIAN) - addr_reg1 = addr_regh; - addr_reg2 = addr_regl; - addr_memh = 0; - addr_meml = 4; -# else - addr_reg1 = addr_regl; - addr_reg2 = addr_regh; - addr_memh = 4; - addr_meml = 0; -# endif -#else - addr_reg1 = addr_regl; - addr_meml = 0; -#endif - -#if defined(CONFIG_SOFTMMU) - tcg_out_opc_sa(s, OPC_SRL, TCG_REG_A0, addr_regl, TARGET_PAGE_BITS - CPU_TLB_ENTRY_BITS); - tcg_out_opc_imm(s, OPC_ANDI, TCG_REG_A0, TCG_REG_A0, (CPU_TLB_SIZE - 1) << CPU_TLB_ENTRY_BITS); - tcg_out_opc_reg(s, OPC_ADDU, TCG_REG_A0, TCG_REG_A0, TCG_AREG0); - tcg_out_opc_imm(s, OPC_LW, TCG_REG_AT, TCG_REG_A0, - offsetof(CPUState, tlb_table[mem_index][0].addr_read) + addr_meml); - tcg_out_movi(s, TCG_TYPE_I32, TCG_REG_T0, TARGET_PAGE_MASK | ((1 << s_bits) - 1)); - tcg_out_opc_reg(s, OPC_AND, TCG_REG_T0, TCG_REG_T0, addr_regl); - -# if TARGET_LONG_BITS == 64 - label3_ptr = s->code_ptr; - tcg_out_opc_imm(s, OPC_BNE, TCG_REG_T0, TCG_REG_AT, 0); - tcg_out_nop(s); - - tcg_out_opc_imm(s, OPC_LW, TCG_REG_AT, TCG_REG_A0, - offsetof(CPUState, tlb_table[mem_index][0].addr_read) + addr_memh); - - label1_ptr = s->code_ptr; - tcg_out_opc_imm(s, OPC_BEQ, addr_regh, TCG_REG_AT, 0); - tcg_out_nop(s); - - reloc_pc16(label3_ptr, (tcg_target_long) s->code_ptr); -# else - label1_ptr = s->code_ptr; - tcg_out_opc_imm(s, OPC_BEQ, TCG_REG_T0, TCG_REG_AT, 0); - tcg_out_nop(s); -# endif - - /* slow path */ - sp_args = TCG_REG_A0; - tcg_out_mov(s, sp_args++, addr_reg1); -# if TARGET_LONG_BITS == 64 - tcg_out_mov(s, sp_args++, addr_reg2); -# endif - tcg_out_movi(s, TCG_TYPE_I32, sp_args++, mem_index); - tcg_out_movi(s, TCG_TYPE_I32, TCG_REG_T9, (tcg_target_long)qemu_ld_helpers[s_bits]); - tcg_out_opc_reg(s, OPC_JALR, TCG_REG_RA, TCG_REG_T9, 0); - tcg_out_nop(s); - - switch(opc) { - case 0: - tcg_out_opc_imm(s, OPC_ANDI, data_reg1, TCG_REG_V0, 0xff); - break; - case 0 | 4: - tcg_out_opc_sa(s, OPC_SLL, TCG_REG_V0, TCG_REG_V0, 24); - tcg_out_opc_sa(s, OPC_SRA, data_reg1, TCG_REG_V0, 24); - break; - case 1: - tcg_out_opc_imm(s, OPC_ANDI, data_reg1, TCG_REG_V0, 0xffff); - break; - case 1 | 4: - tcg_out_opc_sa(s, OPC_SLL, TCG_REG_V0, TCG_REG_V0, 16); - tcg_out_opc_sa(s, OPC_SRA, data_reg1, TCG_REG_V0, 16); - break; - case 2: - tcg_out_mov(s, data_reg1, TCG_REG_V0); - break; - case 3: - tcg_out_mov(s, data_reg2, TCG_REG_V1); - tcg_out_mov(s, data_reg1, TCG_REG_V0); - break; - default: - tcg_abort(); - } - - label2_ptr = s->code_ptr; - tcg_out_opc_imm(s, OPC_BEQ, TCG_REG_ZERO, TCG_REG_ZERO, 0); - tcg_out_nop(s); - - /* label1: fast path */ - reloc_pc16(label1_ptr, (tcg_target_long) s->code_ptr); - - tcg_out_opc_imm(s, OPC_LW, TCG_REG_V0, TCG_REG_A0, - offsetof(CPUState, tlb_table[mem_index][0].addend) + addr_meml); - tcg_out_opc_reg(s, OPC_ADDU, TCG_REG_V0, TCG_REG_V0, addr_regl); - - addr_reg1 = TCG_REG_V0; -#endif - - switch(opc) { - case 0: - tcg_out_opc_imm(s, OPC_LBU, data_reg1, addr_reg1, 0); - break; - case 0 | 4: - tcg_out_opc_imm(s, OPC_LB, data_reg1, addr_reg1, 0); - break; - case 1: - if (TCG_NEED_BSWAP) { - tcg_out_opc_imm(s, OPC_LHU, TCG_REG_T0, addr_reg1, 0); - tcg_out_bswap16(s, data_reg1, TCG_REG_T0); - } else { - tcg_out_opc_imm(s, OPC_LHU, data_reg1, addr_reg1, 0); - } - break; - case 1 | 4: - if (TCG_NEED_BSWAP) { - tcg_out_opc_imm(s, OPC_LHU, TCG_REG_T0, addr_reg1, 0); - tcg_out_bswap16s(s, data_reg1, TCG_REG_T0); - } else { - tcg_out_opc_imm(s, OPC_LH, data_reg1, addr_reg1, 0); - } - break; - case 2: - if (TCG_NEED_BSWAP) { - tcg_out_opc_imm(s, OPC_LW, TCG_REG_T0, addr_reg1, 0); - tcg_out_bswap32(s, data_reg1, TCG_REG_T0); - } else { - tcg_out_opc_imm(s, OPC_LW, data_reg1, addr_reg1, 0); - } - break; - case 3: -#if !defined(CONFIG_SOFTMMU) - tcg_out_mov(s, TCG_REG_V0, addr_reg1); - addr_reg1 = TCG_REG_V0; -#endif - if (TCG_NEED_BSWAP) { - tcg_out_opc_imm(s, OPC_LW, TCG_REG_T0, addr_reg1, 4); - tcg_out_bswap32(s, data_reg1, TCG_REG_T0); - tcg_out_opc_imm(s, OPC_LW, TCG_REG_T0, addr_reg1, 0); - tcg_out_bswap32(s, data_reg2, TCG_REG_T0); - } else { - tcg_out_opc_imm(s, OPC_LW, data_reg1, addr_reg1, 0); - tcg_out_opc_imm(s, OPC_LW, data_reg2, addr_reg1, 4); - } - break; - default: - tcg_abort(); - } - -#if defined(CONFIG_SOFTMMU) - reloc_pc16(label2_ptr, (tcg_target_long) s->code_ptr); -#endif -} - -static void tcg_out_qemu_st(TCGContext *s, const TCGArg *args, - int opc) -{ - int addr_regl, addr_reg1, addr_meml; - int data_regl, data_regh, data_reg1, data_reg2; - int mem_index, s_bits; -#if defined(CONFIG_SOFTMMU) - uint8_t *label1_ptr, *label2_ptr; - int sp_args; -#endif -#if TARGET_LONG_BITS == 64 -# if defined(CONFIG_SOFTMMU) - uint8_t *label3_ptr; -# endif - int addr_regh, addr_reg2, addr_memh; -#endif - - data_regl = *args++; - if (opc == 3) { - data_regh = *args++; -#if defined(TCG_TARGET_WORDS_BIGENDIAN) - data_reg1 = data_regh; - data_reg2 = data_regl; -#else - data_reg1 = data_regl; - data_reg2 = data_regh; -#endif - } else { - data_reg1 = data_regl; - data_reg2 = 0; - data_regh = 0; - } - addr_regl = *args++; -#if TARGET_LONG_BITS == 64 - addr_regh = *args++; -# if defined(TCG_TARGET_WORDS_BIGENDIAN) - addr_reg1 = addr_regh; - addr_reg2 = addr_regl; - addr_memh = 0; - addr_meml = 4; -# else - addr_reg1 = addr_regl; - addr_reg2 = addr_regh; - addr_memh = 4; - addr_meml = 0; -# endif -#else - addr_reg1 = addr_regl; - addr_meml = 0; -#endif - mem_index = *args; - s_bits = opc; - -#if defined(CONFIG_SOFTMMU) - tcg_out_opc_sa(s, OPC_SRL, TCG_REG_A0, addr_regl, TARGET_PAGE_BITS - CPU_TLB_ENTRY_BITS); - tcg_out_opc_imm(s, OPC_ANDI, TCG_REG_A0, TCG_REG_A0, (CPU_TLB_SIZE - 1) << CPU_TLB_ENTRY_BITS); - tcg_out_opc_reg(s, OPC_ADDU, TCG_REG_A0, TCG_REG_A0, TCG_AREG0); - tcg_out_opc_imm(s, OPC_LW, TCG_REG_AT, TCG_REG_A0, - offsetof(CPUState, tlb_table[mem_index][0].addr_write) + addr_meml); - tcg_out_movi(s, TCG_TYPE_I32, TCG_REG_T0, TARGET_PAGE_MASK | ((1 << s_bits) - 1)); - tcg_out_opc_reg(s, OPC_AND, TCG_REG_T0, TCG_REG_T0, addr_regl); - -# if TARGET_LONG_BITS == 64 - label3_ptr = s->code_ptr; - tcg_out_opc_imm(s, OPC_BNE, TCG_REG_T0, TCG_REG_AT, 0); - tcg_out_nop(s); - - tcg_out_opc_imm(s, OPC_LW, TCG_REG_AT, TCG_REG_A0, - offsetof(CPUState, tlb_table[mem_index][0].addr_write) + addr_memh); - - label1_ptr = s->code_ptr; - tcg_out_opc_imm(s, OPC_BEQ, addr_regh, TCG_REG_AT, 0); - tcg_out_nop(s); - - reloc_pc16(label3_ptr, (tcg_target_long) s->code_ptr); -# else - label1_ptr = s->code_ptr; - tcg_out_opc_imm(s, OPC_BEQ, TCG_REG_T0, TCG_REG_AT, 0); - tcg_out_nop(s); -# endif - - /* slow path */ - sp_args = TCG_REG_A0; - tcg_out_mov(s, sp_args++, addr_reg1); -# if TARGET_LONG_BITS == 64 - tcg_out_mov(s, sp_args++, addr_reg2); -# endif - switch(opc) { - case 0: - tcg_out_opc_imm(s, OPC_ANDI, sp_args++, data_reg1, 0xff); - break; - case 1: - tcg_out_opc_imm(s, OPC_ANDI, sp_args++, data_reg1, 0xffff); - break; - case 2: - tcg_out_mov(s, sp_args++, data_reg1); - break; - case 3: - sp_args = (sp_args + 1) & ~1; - tcg_out_mov(s, sp_args++, data_reg1); - tcg_out_mov(s, sp_args++, data_reg2); - break; - default: - tcg_abort(); - } - if (sp_args > TCG_REG_A3) { - /* Push mem_index on the stack */ - tcg_out_movi(s, TCG_TYPE_I32, TCG_REG_AT, mem_index); - tcg_out_st(s, TCG_TYPE_I32, TCG_REG_AT, TCG_REG_SP, 16); - } else { - tcg_out_movi(s, TCG_TYPE_I32, sp_args, mem_index); - } - - tcg_out_movi(s, TCG_TYPE_I32, TCG_REG_T9, (tcg_target_long)qemu_st_helpers[s_bits]); - tcg_out_opc_reg(s, OPC_JALR, TCG_REG_RA, TCG_REG_T9, 0); - tcg_out_nop(s); - - label2_ptr = s->code_ptr; - tcg_out_opc_imm(s, OPC_BEQ, TCG_REG_ZERO, TCG_REG_ZERO, 0); - tcg_out_nop(s); - - /* label1: fast path */ - reloc_pc16(label1_ptr, (tcg_target_long) s->code_ptr); - - tcg_out_opc_imm(s, OPC_LW, TCG_REG_A0, TCG_REG_A0, - offsetof(CPUState, tlb_table[mem_index][0].addend) + addr_meml); - tcg_out_opc_reg(s, OPC_ADDU, TCG_REG_A0, TCG_REG_A0, addr_regl); - - addr_reg1 = TCG_REG_A0; -#endif - - switch(opc) { - case 0: - tcg_out_opc_imm(s, OPC_SB, data_reg1, addr_reg1, 0); - break; - case 1: - if (TCG_NEED_BSWAP) { - tcg_out_bswap16(s, TCG_REG_T0, data_reg1); - tcg_out_opc_imm(s, OPC_SH, TCG_REG_T0, addr_reg1, 0); - } else { - tcg_out_opc_imm(s, OPC_SH, data_reg1, addr_reg1, 0); - } - break; - case 2: - if (TCG_NEED_BSWAP) { - tcg_out_bswap32(s, TCG_REG_T0, data_reg1); - tcg_out_opc_imm(s, OPC_SW, TCG_REG_T0, addr_reg1, 0); - } else { - tcg_out_opc_imm(s, OPC_SW, data_reg1, addr_reg1, 0); - } - break; - case 3: - if (TCG_NEED_BSWAP) { - tcg_out_bswap32(s, TCG_REG_T0, data_reg2); - tcg_out_opc_imm(s, OPC_SW, TCG_REG_T0, addr_reg1, 0); - tcg_out_bswap32(s, TCG_REG_T0, data_reg1); - tcg_out_opc_imm(s, OPC_SW, TCG_REG_T0, addr_reg1, 4); - } else { - tcg_out_opc_imm(s, OPC_SW, data_reg1, addr_reg1, 0); - tcg_out_opc_imm(s, OPC_SW, data_reg2, addr_reg1, 4); - } - break; - default: - tcg_abort(); - } - -#if defined(CONFIG_SOFTMMU) - reloc_pc16(label2_ptr, (tcg_target_long) s->code_ptr); -#endif -} - -static inline void tcg_out_op(TCGContext *s, int opc, - const TCGArg *args, const int *const_args) -{ - switch(opc) { - case INDEX_op_exit_tb: - tcg_out_movi(s, TCG_TYPE_I32, TCG_REG_V0, args[0]); - tcg_out_movi(s, TCG_TYPE_I32, TCG_REG_AT, (tcg_target_long)tb_ret_addr); - tcg_out_opc_reg(s, OPC_JR, 0, TCG_REG_AT, 0); - tcg_out_nop(s); - break; - case INDEX_op_goto_tb: - if (s->tb_jmp_offset) { - /* direct jump method */ - tcg_abort(); - } else { - /* indirect jump method */ - tcg_out_movi(s, TCG_TYPE_PTR, TCG_REG_AT, (tcg_target_long)(s->tb_next + args[0])); - tcg_out_ld(s, TCG_TYPE_PTR, TCG_REG_AT, TCG_REG_AT, 0); - tcg_out_opc_reg(s, OPC_JR, 0, TCG_REG_AT, 0); - } - tcg_out_nop(s); - s->tb_next_offset[args[0]] = s->code_ptr - s->code_buf; - break; - case INDEX_op_call: - tcg_out_opc_reg(s, OPC_JALR, TCG_REG_RA, args[0], 0); - tcg_out_nop(s); - break; - case INDEX_op_jmp: - tcg_out_opc_reg(s, OPC_JR, 0, args[0], 0); - tcg_out_nop(s); - break; - case INDEX_op_br: - tcg_out_brcond(s, TCG_COND_EQ, TCG_REG_ZERO, TCG_REG_ZERO, args[0]); - break; - - case INDEX_op_mov_i32: - tcg_out_mov(s, args[0], args[1]); - break; - case INDEX_op_movi_i32: - tcg_out_movi(s, TCG_TYPE_I32, args[0], args[1]); - break; - - case INDEX_op_ld8u_i32: - tcg_out_ldst(s, OPC_LBU, args[0], args[1], args[2]); - break; - case INDEX_op_ld8s_i32: - tcg_out_ldst(s, OPC_LB, args[0], args[1], args[2]); - break; - case INDEX_op_ld16u_i32: - tcg_out_ldst(s, OPC_LHU, args[0], args[1], args[2]); - break; - case INDEX_op_ld16s_i32: - tcg_out_ldst(s, OPC_LH, args[0], args[1], args[2]); - break; - case INDEX_op_ld_i32: - tcg_out_ldst(s, OPC_LW, args[0], args[1], args[2]); - break; - case INDEX_op_st8_i32: - tcg_out_ldst(s, OPC_SB, args[0], args[1], args[2]); - break; - case INDEX_op_st16_i32: - tcg_out_ldst(s, OPC_SH, args[0], args[1], args[2]); - break; - case INDEX_op_st_i32: - tcg_out_ldst(s, OPC_SW, args[0], args[1], args[2]); - break; - - case INDEX_op_add_i32: - if (const_args[2]) { - tcg_out_opc_imm(s, OPC_ADDIU, args[0], args[1], args[2]); - } else { - tcg_out_opc_reg(s, OPC_ADDU, args[0], args[1], args[2]); - } - break; - case INDEX_op_add2_i32: - if (const_args[4]) { - tcg_out_opc_imm(s, OPC_ADDIU, TCG_REG_AT, args[2], args[4]); - } else { - tcg_out_opc_reg(s, OPC_ADDU, TCG_REG_AT, args[2], args[4]); - } - tcg_out_opc_reg(s, OPC_SLTU, TCG_REG_T0, TCG_REG_AT, args[2]); - if (const_args[5]) { - tcg_out_opc_imm(s, OPC_ADDIU, args[1], args[3], args[5]); - } else { - tcg_out_opc_reg(s, OPC_ADDU, args[1], args[3], args[5]); - } - tcg_out_opc_reg(s, OPC_ADDU, args[1], args[1], TCG_REG_T0); - tcg_out_mov(s, args[0], TCG_REG_AT); - break; - case INDEX_op_sub_i32: - if (const_args[2]) { - tcg_out_opc_imm(s, OPC_ADDIU, args[0], args[1], -args[2]); - } else { - tcg_out_opc_reg(s, OPC_SUBU, args[0], args[1], args[2]); - } - break; - case INDEX_op_sub2_i32: - if (const_args[4]) { - tcg_out_opc_imm(s, OPC_ADDIU, TCG_REG_AT, args[2], -args[4]); - } else { - tcg_out_opc_reg(s, OPC_SUBU, TCG_REG_AT, args[2], args[4]); - } - tcg_out_opc_reg(s, OPC_SLTU, TCG_REG_T0, args[2], TCG_REG_AT); - if (const_args[5]) { - tcg_out_opc_imm(s, OPC_ADDIU, args[1], args[3], -args[5]); - } else { - tcg_out_opc_reg(s, OPC_SUBU, args[1], args[3], args[5]); - } - tcg_out_opc_reg(s, OPC_SUBU, args[1], args[1], TCG_REG_T0); - tcg_out_mov(s, args[0], TCG_REG_AT); - break; - case INDEX_op_mul_i32: - tcg_out_opc_reg(s, OPC_MULT, 0, args[1], args[2]); - tcg_out_opc_reg(s, OPC_MFLO, args[0], 0, 0); - break; - case INDEX_op_mulu2_i32: - tcg_out_opc_reg(s, OPC_MULTU, 0, args[2], args[3]); - tcg_out_opc_reg(s, OPC_MFLO, args[0], 0, 0); - tcg_out_opc_reg(s, OPC_MFHI, args[1], 0, 0); - break; - case INDEX_op_div_i32: - tcg_out_opc_reg(s, OPC_DIV, 0, args[1], args[2]); - tcg_out_opc_reg(s, OPC_MFLO, args[0], 0, 0); - break; - case INDEX_op_divu_i32: - tcg_out_opc_reg(s, OPC_DIVU, 0, args[1], args[2]); - tcg_out_opc_reg(s, OPC_MFLO, args[0], 0, 0); - break; - case INDEX_op_rem_i32: - tcg_out_opc_reg(s, OPC_DIV, 0, args[1], args[2]); - tcg_out_opc_reg(s, OPC_MFHI, args[0], 0, 0); - break; - case INDEX_op_remu_i32: - tcg_out_opc_reg(s, OPC_DIVU, 0, args[1], args[2]); - tcg_out_opc_reg(s, OPC_MFHI, args[0], 0, 0); - break; - - case INDEX_op_and_i32: - if (const_args[2]) { - tcg_out_opc_imm(s, OPC_ANDI, args[0], args[1], args[2]); - } else { - tcg_out_opc_reg(s, OPC_AND, args[0], args[1], args[2]); - } - break; - case INDEX_op_or_i32: - if (const_args[2]) { - tcg_out_opc_imm(s, OPC_ORI, args[0], args[1], args[2]); - } else { - tcg_out_opc_reg(s, OPC_OR, args[0], args[1], args[2]); - } - break; - case INDEX_op_not_i32: - tcg_out_opc_reg(s, OPC_NOR, args[0], args[1], args[1]); - break; - case INDEX_op_xor_i32: - if (const_args[2]) { - tcg_out_opc_imm(s, OPC_XORI, args[0], args[1], args[2]); - } else { - tcg_out_opc_reg(s, OPC_XOR, args[0], args[1], args[2]); - } - break; - - case INDEX_op_sar_i32: - if (const_args[2]) { - tcg_out_opc_sa(s, OPC_SRA, args[0], args[1], args[2]); - } else { - tcg_out_opc_reg(s, OPC_SRAV, args[0], args[2], args[1]); - } - break; - case INDEX_op_shl_i32: - if (const_args[2]) { - tcg_out_opc_sa(s, OPC_SLL, args[0], args[1], args[2]); - } else { - tcg_out_opc_reg(s, OPC_SLLV, args[0], args[2], args[1]); - } - break; - case INDEX_op_shr_i32: - if (const_args[2]) { - tcg_out_opc_sa(s, OPC_SRL, args[0], args[1], args[2]); - } else { - tcg_out_opc_reg(s, OPC_SRLV, args[0], args[2], args[1]); - } - break; - - case INDEX_op_brcond_i32: - tcg_out_brcond(s, args[2], args[0], args[1], args[3]); - break; - case INDEX_op_brcond2_i32: - tcg_out_brcond2(s, args[4], args[0], args[1], args[2], args[3], args[5]); - break; - - case INDEX_op_qemu_ld8u: - tcg_out_qemu_ld(s, args, 0); - break; - case INDEX_op_qemu_ld8s: - tcg_out_qemu_ld(s, args, 0 | 4); - break; - case INDEX_op_qemu_ld16u: - tcg_out_qemu_ld(s, args, 1); - break; - case INDEX_op_qemu_ld16s: - tcg_out_qemu_ld(s, args, 1 | 4); - break; - case INDEX_op_qemu_ld32u: - tcg_out_qemu_ld(s, args, 2); - break; - case INDEX_op_qemu_ld64: - tcg_out_qemu_ld(s, args, 3); - break; - case INDEX_op_qemu_st8: - tcg_out_qemu_st(s, args, 0); - break; - case INDEX_op_qemu_st16: - tcg_out_qemu_st(s, args, 1); - break; - case INDEX_op_qemu_st32: - tcg_out_qemu_st(s, args, 2); - break; - case INDEX_op_qemu_st64: - tcg_out_qemu_st(s, args, 3); - break; - - default: - tcg_abort(); - } -} - -static const TCGTargetOpDef mips_op_defs[] = { - { INDEX_op_exit_tb, { } }, - { INDEX_op_goto_tb, { } }, - { INDEX_op_call, { "C" } }, - { INDEX_op_jmp, { "r" } }, - { INDEX_op_br, { } }, - - { INDEX_op_mov_i32, { "r", "r" } }, - { INDEX_op_movi_i32, { "r" } }, - { INDEX_op_ld8u_i32, { "r", "r" } }, - { INDEX_op_ld8s_i32, { "r", "r" } }, - { INDEX_op_ld16u_i32, { "r", "r" } }, - { INDEX_op_ld16s_i32, { "r", "r" } }, - { INDEX_op_ld_i32, { "r", "r" } }, - { INDEX_op_st8_i32, { "rZ", "r" } }, - { INDEX_op_st16_i32, { "rZ", "r" } }, - { INDEX_op_st_i32, { "rZ", "r" } }, - - { INDEX_op_add_i32, { "r", "rZ", "rJZ" } }, - { INDEX_op_mul_i32, { "r", "rZ", "rZ" } }, - { INDEX_op_mulu2_i32, { "r", "r", "rZ", "rZ" } }, - { INDEX_op_div_i32, { "r", "rZ", "rZ" } }, - { INDEX_op_divu_i32, { "r", "rZ", "rZ" } }, - { INDEX_op_rem_i32, { "r", "rZ", "rZ" } }, - { INDEX_op_remu_i32, { "r", "rZ", "rZ" } }, - { INDEX_op_sub_i32, { "r", "rZ", "rJZ" } }, - - { INDEX_op_and_i32, { "r", "rZ", "rIZ" } }, - { INDEX_op_not_i32, { "r", "rZ" } }, - { INDEX_op_or_i32, { "r", "rZ", "rIZ" } }, - { INDEX_op_xor_i32, { "r", "rZ", "rIZ" } }, - - { INDEX_op_shl_i32, { "r", "rZ", "riZ" } }, - { INDEX_op_shr_i32, { "r", "rZ", "riZ" } }, - { INDEX_op_sar_i32, { "r", "rZ", "riZ" } }, - - { INDEX_op_brcond_i32, { "rZ", "rZ" } }, - - { INDEX_op_add2_i32, { "r", "r", "rZ", "rZ", "rJZ", "rJZ" } }, - { INDEX_op_sub2_i32, { "r", "r", "rZ", "rZ", "rJZ", "rJZ" } }, - { INDEX_op_brcond2_i32, { "rZ", "rZ", "rZ", "rZ" } }, - -#if TARGET_LONG_BITS == 32 - { INDEX_op_qemu_ld8u, { "L", "lZ" } }, - { INDEX_op_qemu_ld8s, { "L", "lZ" } }, - { INDEX_op_qemu_ld16u, { "L", "lZ" } }, - { INDEX_op_qemu_ld16s, { "L", "lZ" } }, - { INDEX_op_qemu_ld32u, { "L", "lZ" } }, - { INDEX_op_qemu_ld64, { "L", "L", "lZ" } }, - - { INDEX_op_qemu_st8, { "SZ", "SZ" } }, - { INDEX_op_qemu_st16, { "SZ", "SZ" } }, - { INDEX_op_qemu_st32, { "SZ", "SZ" } }, - { INDEX_op_qemu_st64, { "SZ", "SZ", "SZ" } }, -#else - { INDEX_op_qemu_ld8u, { "L", "lZ", "lZ" } }, - { INDEX_op_qemu_ld8s, { "L", "lZ", "lZ" } }, - { INDEX_op_qemu_ld16u, { "L", "lZ", "lZ" } }, - { INDEX_op_qemu_ld16s, { "L", "lZ", "lZ" } }, - { INDEX_op_qemu_ld32u, { "L", "lZ", "lZ" } }, - { INDEX_op_qemu_ld64, { "L", "L", "lZ", "lZ" } }, - - { INDEX_op_qemu_st8, { "SZ", "SZ", "SZ" } }, - { INDEX_op_qemu_st16, { "SZ", "SZ", "SZ" } }, - { INDEX_op_qemu_st32, { "SZ", "SZ", "SZ" } }, - { INDEX_op_qemu_st64, { "SZ", "SZ", "SZ", "SZ" } }, -#endif - { -1 }, -}; - -static int tcg_target_callee_save_regs[] = { - TCG_REG_S0, - TCG_REG_S1, - TCG_REG_S2, - TCG_REG_S3, - TCG_REG_S4, - TCG_REG_S5, - TCG_REG_S6, - TCG_REG_S7, - TCG_REG_GP, - /* TCG_REG_FP, */ /* currently used for the global env, so np - need to save */ - TCG_REG_RA, /* should be last for ABI compliance */ -}; - -/* Generate global QEMU prologue and epilogue code */ -void tcg_target_qemu_prologue(TCGContext *s) -{ - int i, frame_size; - - /* reserve some stack space */ - frame_size = ARRAY_SIZE(tcg_target_callee_save_regs) * 4 - + TCG_STATIC_CALL_ARGS_SIZE; - frame_size = (frame_size + TCG_TARGET_STACK_ALIGN - 1) & - ~(TCG_TARGET_STACK_ALIGN - 1); - - /* TB prologue */ - tcg_out_addi(s, TCG_REG_SP, -frame_size); - for(i = 0 ; i < ARRAY_SIZE(tcg_target_callee_save_regs) ; i++) { - tcg_out_st(s, TCG_TYPE_I32, tcg_target_callee_save_regs[i], - TCG_REG_SP, TCG_STATIC_CALL_ARGS_SIZE + i * 4); - } - - /* Call generated code */ - tcg_out_opc_reg(s, OPC_JR, 0, TCG_REG_A0, 0); - tcg_out_nop(s); - tb_ret_addr = s->code_ptr; - - /* TB epilogue */ - for(i = 0 ; i < ARRAY_SIZE(tcg_target_callee_save_regs) ; i++) { - tcg_out_ld(s, TCG_TYPE_I32, tcg_target_callee_save_regs[i], - TCG_REG_SP, TCG_STATIC_CALL_ARGS_SIZE + i * 4); - } - - tcg_out_opc_reg(s, OPC_JR, 0, TCG_REG_RA, 0); - tcg_out_addi(s, TCG_REG_SP, frame_size); -} - -void tcg_target_init(TCGContext *s) -{ - tcg_regset_set(tcg_target_available_regs[TCG_TYPE_I32], 0xffffffff); - tcg_regset_set(tcg_target_call_clobber_regs, - (1 << TCG_REG_V0) | - (1 << TCG_REG_V1) | - (1 << TCG_REG_A0) | - (1 << TCG_REG_A1) | - (1 << TCG_REG_A2) | - (1 << TCG_REG_A3) | - (1 << TCG_REG_T1) | - (1 << TCG_REG_T2) | - (1 << TCG_REG_T3) | - (1 << TCG_REG_T4) | - (1 << TCG_REG_T5) | - (1 << TCG_REG_T6) | - (1 << TCG_REG_T7) | - (1 << TCG_REG_T8) | - (1 << TCG_REG_T9)); - - tcg_regset_clear(s->reserved_regs); - tcg_regset_set_reg(s->reserved_regs, TCG_REG_ZERO); /* zero register */ - tcg_regset_set_reg(s->reserved_regs, TCG_REG_K0); /* kernel use only */ - tcg_regset_set_reg(s->reserved_regs, TCG_REG_K1); /* kernel use only */ - tcg_regset_set_reg(s->reserved_regs, TCG_REG_AT); /* internal use */ - tcg_regset_set_reg(s->reserved_regs, TCG_REG_T0); /* internal use */ - tcg_regset_set_reg(s->reserved_regs, TCG_REG_RA); /* return address */ - tcg_regset_set_reg(s->reserved_regs, TCG_REG_SP); /* stack pointer */ - - tcg_add_target_add_op_defs(mips_op_defs); -} diff --git a/qemu/qemu-git/tcg/mips/.svn/text-base/tcg-target.h.svn-base b/qemu/qemu-git/tcg/mips/.svn/text-base/tcg-target.h.svn-base deleted file mode 100644 index 46760a5..0000000 --- a/qemu/qemu-git/tcg/mips/.svn/text-base/tcg-target.h.svn-base +++ /dev/null @@ -1,104 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2008-2009 Arnaud Patard - * Copyright (c) 2009 Aurelien Jarno - * Based on i386/tcg-target.c - Copyright (c) 2008 Fabrice Bellard - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ -#define TCG_TARGET_MIPS 1 - -#define TCG_TARGET_REG_BITS 32 -#ifdef __MIPSEB__ -# define TCG_TARGET_WORDS_BIGENDIAN -#endif - -#define TCG_TARGET_NB_REGS 32 - -enum { - TCG_REG_ZERO = 0, - TCG_REG_AT, - TCG_REG_V0, - TCG_REG_V1, - TCG_REG_A0, - TCG_REG_A1, - TCG_REG_A2, - TCG_REG_A3, - TCG_REG_T0, - TCG_REG_T1, - TCG_REG_T2, - TCG_REG_T3, - TCG_REG_T4, - TCG_REG_T5, - TCG_REG_T6, - TCG_REG_T7, - TCG_REG_S0, - TCG_REG_S1, - TCG_REG_S2, - TCG_REG_S3, - TCG_REG_S4, - TCG_REG_S5, - TCG_REG_S6, - TCG_REG_S7, - TCG_REG_T8, - TCG_REG_T9, - TCG_REG_K0, - TCG_REG_K1, - TCG_REG_GP, - TCG_REG_SP, - TCG_REG_FP, - TCG_REG_RA, -}; - -#define TCG_CT_CONST_ZERO 0x100 -#define TCG_CT_CONST_U16 0x200 -#define TCG_CT_CONST_S16 0x400 - -/* used for function call generation */ -#define TCG_REG_CALL_STACK TCG_REG_SP -#define TCG_TARGET_STACK_ALIGN 8 -#define TCG_TARGET_CALL_STACK_OFFSET 16 -#define TCG_TARGET_CALL_ALIGN_ARGS 1 - -/* optional instructions */ -#define TCG_TARGET_HAS_div_i32 -#define TCG_TARGET_HAS_not_i32 -#undef TCG_TARGET_HAS_ext8s_i32 -#undef TCG_TARGET_HAS_ext16s_i32 -#undef TCG_TARGET_HAS_bswap32_i32 -#undef TCG_TARGET_HAS_bswap16_i32 -#undef TCG_TARGET_HAS_rot_i32 - -/* optional instructions automatically implemented */ -#undef TCG_TARGET_HAS_neg_i32 /* sub rd, zero, rt */ -#undef TCG_TARGET_HAS_ext8u_i32 /* andi rt, rs, 0xff */ -#undef TCG_TARGET_HAS_ext16u_i32 /* andi rt, rs, 0xffff */ - -/* Note: must be synced with dyngen-exec.h */ -#define TCG_AREG0 TCG_REG_FP -#define TCG_AREG1 TCG_REG_S0 -#define TCG_AREG2 TCG_REG_S1 - -#include - -static inline void flush_icache_range(unsigned long start, unsigned long stop) -{ - cacheflush ((void *)start, stop-start, ICACHE); -} diff --git a/qemu/qemu-git/tcg/ppc/.svn/all-wcprops b/qemu/qemu-git/tcg/ppc/.svn/all-wcprops deleted file mode 100644 index c11d654..0000000 --- a/qemu/qemu-git/tcg/ppc/.svn/all-wcprops +++ /dev/null @@ -1,17 +0,0 @@ -K 25 -svn:wc:ra_dav:version-url -V 47 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/ppc -END -tcg-target.c -K 25 -svn:wc:ra_dav:version-url -V 60 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/ppc/tcg-target.c -END -tcg-target.h -K 25 -svn:wc:ra_dav:version-url -V 60 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/ppc/tcg-target.h -END diff --git a/qemu/qemu-git/tcg/ppc/.svn/entries b/qemu/qemu-git/tcg/ppc/.svn/entries deleted file mode 100644 index 4e89085..0000000 --- a/qemu/qemu-git/tcg/ppc/.svn/entries +++ /dev/null @@ -1,96 +0,0 @@ -10 - -dir -11 -http://svn.code.sf.net/p/x49gp/code/qemu/qemu-git/tcg/ppc -http://svn.code.sf.net/p/x49gp/code - - - -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - -481df3bd-3408-496c-b7de-451e46197bb5 - -tcg-target.c -file - - - - -2013-08-23T00:54:47.000000Z -5d6bb229453943c26c91cd2499c4ad55 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -45330 - -tcg-target.h -file - - - - -2013-08-23T00:54:47.000000Z -d00ba062f95acc9883ce831e2e11f85d -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -2482 - diff --git a/qemu/qemu-git/tcg/ppc/.svn/text-base/tcg-target.c.svn-base b/qemu/qemu-git/tcg/ppc/.svn/text-base/tcg-target.c.svn-base deleted file mode 100644 index 07e6941..0000000 --- a/qemu/qemu-git/tcg/ppc/.svn/text-base/tcg-target.c.svn-base +++ /dev/null @@ -1,1615 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2008 Fabrice Bellard - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ - -static uint8_t *tb_ret_addr; - -#ifdef __APPLE__ -#define LINKAGE_AREA_SIZE 24 -#define LR_OFFSET 8 -#elif defined _AIX -#define LINKAGE_AREA_SIZE 52 -#define LR_OFFSET 8 -#else -#define LINKAGE_AREA_SIZE 8 -#define LR_OFFSET 4 -#endif - -#define FAST_PATH -#if TARGET_PHYS_ADDR_BITS <= 32 -#define ADDEND_OFFSET 0 -#else -#define ADDEND_OFFSET 4 -#endif - -#ifndef GUEST_BASE -#define GUEST_BASE 0 -#endif - -#ifdef CONFIG_USE_GUEST_BASE -#define TCG_GUEST_BASE_REG 30 -#else -#define TCG_GUEST_BASE_REG 0 -#endif - -#ifndef NDEBUG -static const char * const tcg_target_reg_names[TCG_TARGET_NB_REGS] = { - "r0", - "r1", - "rp", - "r3", - "r4", - "r5", - "r6", - "r7", - "r8", - "r9", - "r10", - "r11", - "r12", - "r13", - "r14", - "r15", - "r16", - "r17", - "r18", - "r19", - "r20", - "r21", - "r22", - "r23", - "r24", - "r25", - "r26", - "r27", - "r28", - "r29", - "r30", - "r31" -}; -#endif - -static const int tcg_target_reg_alloc_order[] = { - TCG_REG_R14, - TCG_REG_R15, - TCG_REG_R16, - TCG_REG_R17, - TCG_REG_R18, - TCG_REG_R19, - TCG_REG_R20, - TCG_REG_R21, - TCG_REG_R22, - TCG_REG_R23, - TCG_REG_R28, - TCG_REG_R29, - TCG_REG_R30, - TCG_REG_R31, -#ifdef __APPLE__ - TCG_REG_R2, -#endif - TCG_REG_R3, - TCG_REG_R4, - TCG_REG_R5, - TCG_REG_R6, - TCG_REG_R7, - TCG_REG_R8, - TCG_REG_R9, - TCG_REG_R10, -#ifndef __APPLE__ - TCG_REG_R11, -#endif - TCG_REG_R12, -#ifndef __linux__ - TCG_REG_R13, -#endif - TCG_REG_R24, - TCG_REG_R25, - TCG_REG_R26, - TCG_REG_R27 -}; - -static const int tcg_target_call_iarg_regs[] = { - TCG_REG_R3, - TCG_REG_R4, - TCG_REG_R5, - TCG_REG_R6, - TCG_REG_R7, - TCG_REG_R8, - TCG_REG_R9, - TCG_REG_R10 -}; - -static const int tcg_target_call_oarg_regs[2] = { - TCG_REG_R3, - TCG_REG_R4 -}; - -static const int tcg_target_callee_save_regs[] = { -#ifdef __APPLE__ - TCG_REG_R11, - TCG_REG_R13, -#endif -#ifdef _AIX - TCG_REG_R13, -#endif - TCG_REG_R14, - TCG_REG_R15, - TCG_REG_R16, - TCG_REG_R17, - TCG_REG_R18, - TCG_REG_R19, - TCG_REG_R20, - TCG_REG_R21, - TCG_REG_R22, - TCG_REG_R23, - TCG_REG_R24, - TCG_REG_R25, - TCG_REG_R26, - /* TCG_REG_R27, */ /* currently used for the global env, so no - need to save */ - TCG_REG_R28, - TCG_REG_R29, - TCG_REG_R30, - TCG_REG_R31 -}; - -static uint32_t reloc_pc24_val (void *pc, tcg_target_long target) -{ - tcg_target_long disp; - - disp = target - (tcg_target_long) pc; - if ((disp << 6) >> 6 != disp) - tcg_abort (); - - return disp & 0x3fffffc; -} - -static void reloc_pc24 (void *pc, tcg_target_long target) -{ - *(uint32_t *) pc = (*(uint32_t *) pc & ~0x3fffffc) - | reloc_pc24_val (pc, target); -} - -static uint16_t reloc_pc14_val (void *pc, tcg_target_long target) -{ - tcg_target_long disp; - - disp = target - (tcg_target_long) pc; - if (disp != (int16_t) disp) - tcg_abort (); - - return disp & 0xfffc; -} - -static void reloc_pc14 (void *pc, tcg_target_long target) -{ - *(uint32_t *) pc = (*(uint32_t *) pc & ~0xfffc) - | reloc_pc14_val (pc, target); -} - -static void patch_reloc(uint8_t *code_ptr, int type, - tcg_target_long value, tcg_target_long addend) -{ - value += addend; - switch (type) { - case R_PPC_REL14: - reloc_pc14 (code_ptr, value); - break; - case R_PPC_REL24: - reloc_pc24 (code_ptr, value); - break; - default: - tcg_abort(); - } -} - -/* maximum number of register used for input function arguments */ -static int tcg_target_get_call_iarg_regs_count(int flags) -{ - return ARRAY_SIZE (tcg_target_call_iarg_regs); -} - -/* parse target specific constraints */ -static int target_parse_constraint(TCGArgConstraint *ct, const char **pct_str) -{ - const char *ct_str; - - ct_str = *pct_str; - switch (ct_str[0]) { - case 'A': case 'B': case 'C': case 'D': - ct->ct |= TCG_CT_REG; - tcg_regset_set_reg(ct->u.regs, 3 + ct_str[0] - 'A'); - break; - case 'r': - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, 0xffffffff); - break; -#ifdef CONFIG_SOFTMMU - case 'L': /* qemu_ld constraint */ - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, 0xffffffff); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R3); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R4); - break; - case 'K': /* qemu_st[8..32] constraint */ - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, 0xffffffff); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R3); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R4); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R5); -#if TARGET_LONG_BITS == 64 - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R6); -#endif - break; - case 'M': /* qemu_st64 constraint */ - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, 0xffffffff); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R3); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R4); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R5); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R6); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R7); - break; -#else - case 'L': - case 'K': - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, 0xffffffff); - break; - case 'M': - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, 0xffffffff); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_R3); - break; -#endif - default: - return -1; - } - ct_str++; - *pct_str = ct_str; - return 0; -} - -/* test if a constant matches the constraint */ -static int tcg_target_const_match(tcg_target_long val, - const TCGArgConstraint *arg_ct) -{ - int ct; - - ct = arg_ct->ct; - if (ct & TCG_CT_CONST) - return 1; - return 0; -} - -#define OPCD(opc) ((opc)<<26) -#define XO31(opc) (OPCD(31)|((opc)<<1)) -#define XO19(opc) (OPCD(19)|((opc)<<1)) - -#define B OPCD(18) -#define BC OPCD(16) -#define LBZ OPCD(34) -#define LHZ OPCD(40) -#define LHA OPCD(42) -#define LWZ OPCD(32) -#define STB OPCD(38) -#define STH OPCD(44) -#define STW OPCD(36) - -#define ADDI OPCD(14) -#define ADDIS OPCD(15) -#define ORI OPCD(24) -#define ORIS OPCD(25) -#define XORI OPCD(26) -#define XORIS OPCD(27) -#define ANDI OPCD(28) -#define ANDIS OPCD(29) -#define MULLI OPCD( 7) -#define CMPLI OPCD(10) -#define CMPI OPCD(11) - -#define LWZU OPCD(33) -#define STWU OPCD(37) - -#define RLWINM OPCD(21) - -#define BCLR XO19( 16) -#define BCCTR XO19(528) -#define CRAND XO19(257) -#define CRANDC XO19(129) -#define CRNAND XO19(225) -#define CROR XO19(449) - -#define EXTSB XO31(954) -#define EXTSH XO31(922) -#define ADD XO31(266) -#define ADDE XO31(138) -#define ADDC XO31( 10) -#define AND XO31( 28) -#define SUBF XO31( 40) -#define SUBFC XO31( 8) -#define SUBFE XO31(136) -#define OR XO31(444) -#define XOR XO31(316) -#define MULLW XO31(235) -#define MULHWU XO31( 11) -#define DIVW XO31(491) -#define DIVWU XO31(459) -#define CMP XO31( 0) -#define CMPL XO31( 32) -#define LHBRX XO31(790) -#define LWBRX XO31(534) -#define STHBRX XO31(918) -#define STWBRX XO31(662) -#define MFSPR XO31(339) -#define MTSPR XO31(467) -#define SRAWI XO31(824) -#define NEG XO31(104) - -#define LBZX XO31( 87) -#define LHZX XO31(279) -#define LHAX XO31(343) -#define LWZX XO31( 23) -#define STBX XO31(215) -#define STHX XO31(407) -#define STWX XO31(151) - -#define SPR(a,b) ((((a)<<5)|(b))<<11) -#define LR SPR(8, 0) -#define CTR SPR(9, 0) - -#define SLW XO31( 24) -#define SRW XO31(536) -#define SRAW XO31(792) - -#define TW XO31(4) -#define TRAP (TW | TO (31)) - -#define RT(r) ((r)<<21) -#define RS(r) ((r)<<21) -#define RA(r) ((r)<<16) -#define RB(r) ((r)<<11) -#define TO(t) ((t)<<21) -#define SH(s) ((s)<<11) -#define MB(b) ((b)<<6) -#define ME(e) ((e)<<1) -#define BO(o) ((o)<<21) - -#define LK 1 - -#define TAB(t,a,b) (RT(t) | RA(a) | RB(b)) -#define SAB(s,a,b) (RS(s) | RA(a) | RB(b)) - -#define BF(n) ((n)<<23) -#define BI(n, c) (((c)+((n)*4))<<16) -#define BT(n, c) (((c)+((n)*4))<<21) -#define BA(n, c) (((c)+((n)*4))<<16) -#define BB(n, c) (((c)+((n)*4))<<11) - -#define BO_COND_TRUE BO (12) -#define BO_COND_FALSE BO (4) -#define BO_ALWAYS BO (20) - -enum { - CR_LT, - CR_GT, - CR_EQ, - CR_SO -}; - -static const uint32_t tcg_to_bc[10] = { - [TCG_COND_EQ] = BC | BI (7, CR_EQ) | BO_COND_TRUE, - [TCG_COND_NE] = BC | BI (7, CR_EQ) | BO_COND_FALSE, - [TCG_COND_LT] = BC | BI (7, CR_LT) | BO_COND_TRUE, - [TCG_COND_GE] = BC | BI (7, CR_LT) | BO_COND_FALSE, - [TCG_COND_LE] = BC | BI (7, CR_GT) | BO_COND_FALSE, - [TCG_COND_GT] = BC | BI (7, CR_GT) | BO_COND_TRUE, - [TCG_COND_LTU] = BC | BI (7, CR_LT) | BO_COND_TRUE, - [TCG_COND_GEU] = BC | BI (7, CR_LT) | BO_COND_FALSE, - [TCG_COND_LEU] = BC | BI (7, CR_GT) | BO_COND_FALSE, - [TCG_COND_GTU] = BC | BI (7, CR_GT) | BO_COND_TRUE, -}; - -static void tcg_out_mov(TCGContext *s, int ret, int arg) -{ - tcg_out32 (s, OR | SAB (arg, ret, arg)); -} - -static void tcg_out_movi(TCGContext *s, TCGType type, - int ret, tcg_target_long arg) -{ - if (arg == (int16_t) arg) - tcg_out32 (s, ADDI | RT (ret) | RA (0) | (arg & 0xffff)); - else { - tcg_out32 (s, ADDIS | RT (ret) | RA (0) | ((arg >> 16) & 0xffff)); - if (arg & 0xffff) - tcg_out32 (s, ORI | RS (ret) | RA (ret) | (arg & 0xffff)); - } -} - -static void tcg_out_ldst (TCGContext *s, int ret, int addr, - int offset, int op1, int op2) -{ - if (offset == (int16_t) offset) - tcg_out32 (s, op1 | RT (ret) | RA (addr) | (offset & 0xffff)); - else { - tcg_out_movi (s, TCG_TYPE_I32, 0, offset); - tcg_out32 (s, op2 | RT (ret) | RA (addr) | RB (0)); - } -} - -static void tcg_out_b (TCGContext *s, int mask, tcg_target_long target) -{ - tcg_target_long disp; - - disp = target - (tcg_target_long) s->code_ptr; - if ((disp << 6) >> 6 == disp) - tcg_out32 (s, B | (disp & 0x3fffffc) | mask); - else { - tcg_out_movi (s, TCG_TYPE_I32, 0, (tcg_target_long) target); - tcg_out32 (s, MTSPR | RS (0) | CTR); - tcg_out32 (s, BCCTR | BO_ALWAYS | mask); - } -} - -static void tcg_out_call (TCGContext *s, tcg_target_long arg, int const_arg) -{ -#ifdef _AIX - int reg; - - if (const_arg) { - reg = 2; - tcg_out_movi (s, TCG_TYPE_I32, reg, arg); - } - else reg = arg; - - tcg_out32 (s, LWZ | RT (0) | RA (reg)); - tcg_out32 (s, MTSPR | RA (0) | CTR); - tcg_out32 (s, LWZ | RT (2) | RA (reg) | 4); - tcg_out32 (s, BCCTR | BO_ALWAYS | LK); -#else - if (const_arg) { - tcg_out_b (s, LK, arg); - } - else { - tcg_out32 (s, MTSPR | RS (arg) | LR); - tcg_out32 (s, BCLR | BO_ALWAYS | LK); - } -#endif -} - -#if defined(CONFIG_SOFTMMU) - -#include "../../softmmu_defs.h" - -static void *qemu_ld_helpers[4] = { - __ldb_mmu, - __ldw_mmu, - __ldl_mmu, - __ldq_mmu, -}; - -static void *qemu_st_helpers[4] = { - __stb_mmu, - __stw_mmu, - __stl_mmu, - __stq_mmu, -}; -#endif - -static void tcg_out_qemu_ld (TCGContext *s, const TCGArg *args, int opc) -{ - int addr_reg, data_reg, data_reg2, r0, r1, rbase, mem_index, s_bits, bswap; -#ifdef CONFIG_SOFTMMU - int r2; - void *label1_ptr, *label2_ptr; -#endif -#if TARGET_LONG_BITS == 64 - int addr_reg2; -#endif - - data_reg = *args++; - if (opc == 3) - data_reg2 = *args++; - else - data_reg2 = 0; - addr_reg = *args++; -#if TARGET_LONG_BITS == 64 - addr_reg2 = *args++; -#endif - mem_index = *args; - s_bits = opc & 3; - -#ifdef CONFIG_SOFTMMU - r0 = 3; - r1 = 4; - r2 = 0; - rbase = 0; - - tcg_out32 (s, (RLWINM - | RA (r0) - | RS (addr_reg) - | SH (32 - (TARGET_PAGE_BITS - CPU_TLB_ENTRY_BITS)) - | MB (32 - (CPU_TLB_BITS + CPU_TLB_ENTRY_BITS)) - | ME (31 - CPU_TLB_ENTRY_BITS) - ) - ); - tcg_out32 (s, ADD | RT (r0) | RA (r0) | RB (TCG_AREG0)); - tcg_out32 (s, (LWZU - | RT (r1) - | RA (r0) - | offsetof (CPUState, tlb_table[mem_index][0].addr_read) - ) - ); - tcg_out32 (s, (RLWINM - | RA (r2) - | RS (addr_reg) - | SH (0) - | MB ((32 - s_bits) & 31) - | ME (31 - TARGET_PAGE_BITS) - ) - ); - - tcg_out32 (s, CMP | BF (7) | RA (r2) | RB (r1)); -#if TARGET_LONG_BITS == 64 - tcg_out32 (s, LWZ | RT (r1) | RA (r0) | 4); - tcg_out32 (s, CMP | BF (6) | RA (addr_reg2) | RB (r1)); - tcg_out32 (s, CRAND | BT (7, CR_EQ) | BA (6, CR_EQ) | BB (7, CR_EQ)); -#endif - - label1_ptr = s->code_ptr; -#ifdef FAST_PATH - tcg_out32 (s, BC | BI (7, CR_EQ) | BO_COND_TRUE); -#endif - - /* slow path */ -#if TARGET_LONG_BITS == 32 - tcg_out_mov (s, 3, addr_reg); - tcg_out_movi (s, TCG_TYPE_I32, 4, mem_index); -#else - tcg_out_mov (s, 3, addr_reg2); - tcg_out_mov (s, 4, addr_reg); - tcg_out_movi (s, TCG_TYPE_I32, 5, mem_index); -#endif - - tcg_out_call (s, (tcg_target_long) qemu_ld_helpers[s_bits], 1); - switch (opc) { - case 0|4: - tcg_out32 (s, EXTSB | RA (data_reg) | RS (3)); - break; - case 1|4: - tcg_out32 (s, EXTSH | RA (data_reg) | RS (3)); - break; - case 0: - case 1: - case 2: - if (data_reg != 3) - tcg_out_mov (s, data_reg, 3); - break; - case 3: - if (data_reg == 3) { - if (data_reg2 == 4) { - tcg_out_mov (s, 0, 4); - tcg_out_mov (s, 4, 3); - tcg_out_mov (s, 3, 0); - } - else { - tcg_out_mov (s, data_reg2, 3); - tcg_out_mov (s, 3, 4); - } - } - else { - if (data_reg != 4) tcg_out_mov (s, data_reg, 4); - if (data_reg2 != 3) tcg_out_mov (s, data_reg2, 3); - } - break; - } - label2_ptr = s->code_ptr; - tcg_out32 (s, B); - - /* label1: fast path */ -#ifdef FAST_PATH - reloc_pc14 (label1_ptr, (tcg_target_long) s->code_ptr); -#endif - - /* r0 now contains &env->tlb_table[mem_index][index].addr_read */ - tcg_out32 (s, (LWZ - | RT (r0) - | RA (r0) - | (ADDEND_OFFSET + offsetof (CPUTLBEntry, addend) - - offsetof (CPUTLBEntry, addr_read)) - )); - /* r0 = env->tlb_table[mem_index][index].addend */ - tcg_out32 (s, ADD | RT (r0) | RA (r0) | RB (addr_reg)); - /* r0 = env->tlb_table[mem_index][index].addend + addr */ - -#else /* !CONFIG_SOFTMMU */ - r0 = addr_reg; - r1 = 3; - rbase = GUEST_BASE ? TCG_GUEST_BASE_REG : 0; -#endif - -#ifdef TARGET_WORDS_BIGENDIAN - bswap = 0; -#else - bswap = 1; -#endif - - switch (opc) { - default: - case 0: - tcg_out32 (s, LBZX | TAB (data_reg, rbase, r0)); - break; - case 0|4: - tcg_out32 (s, LBZX | TAB (data_reg, rbase, r0)); - tcg_out32 (s, EXTSB | RA (data_reg) | RS (data_reg)); - break; - case 1: - if (bswap) - tcg_out32 (s, LHBRX | TAB (data_reg, rbase, r0)); - else - tcg_out32 (s, LHZX | TAB (data_reg, rbase, r0)); - break; - case 1|4: - if (bswap) { - tcg_out32 (s, LHBRX | TAB (data_reg, rbase, r0)); - tcg_out32 (s, EXTSH | RA (data_reg) | RS (data_reg)); - } - else tcg_out32 (s, LHAX | TAB (data_reg, rbase, r0)); - break; - case 2: - if (bswap) - tcg_out32 (s, LWBRX | TAB (data_reg, rbase, r0)); - else - tcg_out32 (s, LWZX | TAB (data_reg, rbase, r0)); - break; - case 3: - if (bswap) { - tcg_out32 (s, ADDI | RT (r1) | RA (r0) | 4); - tcg_out32 (s, LWBRX | TAB (data_reg, rbase, r0)); - tcg_out32 (s, LWBRX | TAB (data_reg2, rbase, r1)); - } - else { -#ifdef CONFIG_USE_GUEST_BASE - tcg_out32 (s, ADDI | RT (r1) | RA (r0) | 4); - tcg_out32 (s, LWZX | TAB (data_reg2, rbase, r0)); - tcg_out32 (s, LWZX | TAB (data_reg, rbase, r1)); -#else - if (r0 == data_reg2) { - tcg_out32 (s, LWZ | RT (0) | RA (r0)); - tcg_out32 (s, LWZ | RT (data_reg) | RA (r0) | 4); - tcg_out_mov (s, data_reg2, 0); - } - else { - tcg_out32 (s, LWZ | RT (data_reg2) | RA (r0)); - tcg_out32 (s, LWZ | RT (data_reg) | RA (r0) | 4); - } -#endif - } - break; - } - -#ifdef CONFIG_SOFTMMU - reloc_pc24 (label2_ptr, (tcg_target_long) s->code_ptr); -#endif -} - -static void tcg_out_qemu_st (TCGContext *s, const TCGArg *args, int opc) -{ - int addr_reg, r0, r1, data_reg, data_reg2, mem_index, bswap, rbase; -#ifdef CONFIG_SOFTMMU - int r2, ir; - void *label1_ptr, *label2_ptr; -#endif -#if TARGET_LONG_BITS == 64 - int addr_reg2; -#endif - - data_reg = *args++; - if (opc == 3) - data_reg2 = *args++; - else - data_reg2 = 0; - addr_reg = *args++; -#if TARGET_LONG_BITS == 64 - addr_reg2 = *args++; -#endif - mem_index = *args; - -#ifdef CONFIG_SOFTMMU - r0 = 3; - r1 = 4; - r2 = 0; - rbase = 0; - - tcg_out32 (s, (RLWINM - | RA (r0) - | RS (addr_reg) - | SH (32 - (TARGET_PAGE_BITS - CPU_TLB_ENTRY_BITS)) - | MB (32 - (CPU_TLB_ENTRY_BITS + CPU_TLB_BITS)) - | ME (31 - CPU_TLB_ENTRY_BITS) - ) - ); - tcg_out32 (s, ADD | RT (r0) | RA (r0) | RB (TCG_AREG0)); - tcg_out32 (s, (LWZU - | RT (r1) - | RA (r0) - | offsetof (CPUState, tlb_table[mem_index][0].addr_write) - ) - ); - tcg_out32 (s, (RLWINM - | RA (r2) - | RS (addr_reg) - | SH (0) - | MB ((32 - opc) & 31) - | ME (31 - TARGET_PAGE_BITS) - ) - ); - - tcg_out32 (s, CMP | (7 << 23) | RA (r2) | RB (r1)); -#if TARGET_LONG_BITS == 64 - tcg_out32 (s, LWZ | RT (r1) | RA (r0) | 4); - tcg_out32 (s, CMP | BF (6) | RA (addr_reg2) | RB (r1)); - tcg_out32 (s, CRAND | BT (7, CR_EQ) | BA (6, CR_EQ) | BB (7, CR_EQ)); -#endif - - label1_ptr = s->code_ptr; -#ifdef FAST_PATH - tcg_out32 (s, BC | BI (7, CR_EQ) | BO_COND_TRUE); -#endif - - /* slow path */ -#if TARGET_LONG_BITS == 32 - tcg_out_mov (s, 3, addr_reg); - ir = 4; -#else - tcg_out_mov (s, 3, addr_reg2); - tcg_out_mov (s, 4, addr_reg); -#ifdef TCG_TARGET_CALL_ALIGN_ARGS - ir = 5; -#else - ir = 4; -#endif -#endif - - switch (opc) { - case 0: - tcg_out32 (s, (RLWINM - | RA (ir) - | RS (data_reg) - | SH (0) - | MB (24) - | ME (31))); - break; - case 1: - tcg_out32 (s, (RLWINM - | RA (ir) - | RS (data_reg) - | SH (0) - | MB (16) - | ME (31))); - break; - case 2: - tcg_out_mov (s, ir, data_reg); - break; - case 3: -#ifdef TCG_TARGET_CALL_ALIGN_ARGS - ir = 5; -#endif - tcg_out_mov (s, ir++, data_reg2); - tcg_out_mov (s, ir, data_reg); - break; - } - ir++; - - tcg_out_movi (s, TCG_TYPE_I32, ir, mem_index); - tcg_out_call (s, (tcg_target_long) qemu_st_helpers[opc], 1); - label2_ptr = s->code_ptr; - tcg_out32 (s, B); - - /* label1: fast path */ -#ifdef FAST_PATH - reloc_pc14 (label1_ptr, (tcg_target_long) s->code_ptr); -#endif - - tcg_out32 (s, (LWZ - | RT (r0) - | RA (r0) - | (ADDEND_OFFSET + offsetof (CPUTLBEntry, addend) - - offsetof (CPUTLBEntry, addr_write)) - )); - /* r0 = env->tlb_table[mem_index][index].addend */ - tcg_out32 (s, ADD | RT (r0) | RA (r0) | RB (addr_reg)); - /* r0 = env->tlb_table[mem_index][index].addend + addr */ - -#else /* !CONFIG_SOFTMMU */ - r0 = addr_reg; - r1 = 3; - rbase = GUEST_BASE ? TCG_GUEST_BASE_REG : 0; -#endif - -#ifdef TARGET_WORDS_BIGENDIAN - bswap = 0; -#else - bswap = 1; -#endif - switch (opc) { - case 0: - tcg_out32 (s, STBX | SAB (data_reg, rbase, r0)); - break; - case 1: - if (bswap) - tcg_out32 (s, STHBRX | SAB (data_reg, rbase, r0)); - else - tcg_out32 (s, STHX | SAB (data_reg, rbase, r0)); - break; - case 2: - if (bswap) - tcg_out32 (s, STWBRX | SAB (data_reg, rbase, r0)); - else - tcg_out32 (s, STWX | SAB (data_reg, rbase, r0)); - break; - case 3: - if (bswap) { - tcg_out32 (s, ADDI | RT (r1) | RA (r0) | 4); - tcg_out32 (s, STWBRX | SAB (data_reg, rbase, r0)); - tcg_out32 (s, STWBRX | SAB (data_reg2, rbase, r1)); - } - else { -#ifdef CONFIG_USE_GUEST_BASE - tcg_out32 (s, STWX | SAB (data_reg2, rbase, r0)); - tcg_out32 (s, ADDI | RT (r1) | RA (r0) | 4); - tcg_out32 (s, STWX | SAB (data_reg, rbase, r1)); -#else - tcg_out32 (s, STW | RS (data_reg2) | RA (r0)); - tcg_out32 (s, STW | RS (data_reg) | RA (r0) | 4); -#endif - } - break; - } - -#ifdef CONFIG_SOFTMMU - reloc_pc24 (label2_ptr, (tcg_target_long) s->code_ptr); -#endif -} - -void tcg_target_qemu_prologue (TCGContext *s) -{ - int i, frame_size; - - frame_size = 0 - + LINKAGE_AREA_SIZE - + TCG_STATIC_CALL_ARGS_SIZE - + ARRAY_SIZE (tcg_target_callee_save_regs) * 4 - ; - frame_size = (frame_size + 15) & ~15; - -#ifdef _AIX - { - uint32_t addr; - - /* First emit adhoc function descriptor */ - addr = (uint32_t) s->code_ptr + 12; - tcg_out32 (s, addr); /* entry point */ - s->code_ptr += 8; /* skip TOC and environment pointer */ - } -#endif - tcg_out32 (s, MFSPR | RT (0) | LR); - tcg_out32 (s, STWU | RS (1) | RA (1) | (-frame_size & 0xffff)); - for (i = 0; i < ARRAY_SIZE (tcg_target_callee_save_regs); ++i) - tcg_out32 (s, (STW - | RS (tcg_target_callee_save_regs[i]) - | RA (1) - | (i * 4 + LINKAGE_AREA_SIZE + TCG_STATIC_CALL_ARGS_SIZE) - ) - ); - tcg_out32 (s, STW | RS (0) | RA (1) | (frame_size + LR_OFFSET)); - -#ifdef CONFIG_USE_GUEST_BASE - tcg_out_movi (s, TCG_TYPE_I32, TCG_GUEST_BASE_REG, GUEST_BASE); -#endif - - tcg_out32 (s, MTSPR | RS (3) | CTR); - tcg_out32 (s, BCCTR | BO_ALWAYS); - tb_ret_addr = s->code_ptr; - - for (i = 0; i < ARRAY_SIZE (tcg_target_callee_save_regs); ++i) - tcg_out32 (s, (LWZ - | RT (tcg_target_callee_save_regs[i]) - | RA (1) - | (i * 4 + LINKAGE_AREA_SIZE + TCG_STATIC_CALL_ARGS_SIZE) - ) - ); - tcg_out32 (s, LWZ | RT (0) | RA (1) | (frame_size + LR_OFFSET)); - tcg_out32 (s, MTSPR | RS (0) | LR); - tcg_out32 (s, ADDI | RT (1) | RA (1) | frame_size); - tcg_out32 (s, BCLR | BO_ALWAYS); -} - -static void tcg_out_ld (TCGContext *s, TCGType type, int ret, int arg1, - tcg_target_long arg2) -{ - tcg_out_ldst (s, ret, arg1, arg2, LWZ, LWZX); -} - -static void tcg_out_st (TCGContext *s, TCGType type, int arg, int arg1, - tcg_target_long arg2) -{ - tcg_out_ldst (s, arg, arg1, arg2, STW, STWX); -} - -static void ppc_addi (TCGContext *s, int rt, int ra, tcg_target_long si) -{ - if (!si && rt == ra) - return; - - if (si == (int16_t) si) - tcg_out32 (s, ADDI | RT (rt) | RA (ra) | (si & 0xffff)); - else { - uint16_t h = ((si >> 16) & 0xffff) + ((uint16_t) si >> 15); - tcg_out32 (s, ADDIS | RT (rt) | RA (ra) | h); - tcg_out32 (s, ADDI | RT (rt) | RA (rt) | (si & 0xffff)); - } -} - -static void tcg_out_addi(TCGContext *s, int reg, tcg_target_long val) -{ - ppc_addi (s, reg, reg, val); -} - -static void tcg_out_cmp (TCGContext *s, int cond, TCGArg arg1, TCGArg arg2, - int const_arg2, int cr) -{ - int imm; - uint32_t op; - - switch (cond) { - case TCG_COND_EQ: - case TCG_COND_NE: - if (const_arg2) { - if ((int16_t) arg2 == arg2) { - op = CMPI; - imm = 1; - break; - } - else if ((uint16_t) arg2 == arg2) { - op = CMPLI; - imm = 1; - break; - } - } - op = CMPL; - imm = 0; - break; - - case TCG_COND_LT: - case TCG_COND_GE: - case TCG_COND_LE: - case TCG_COND_GT: - if (const_arg2) { - if ((int16_t) arg2 == arg2) { - op = CMPI; - imm = 1; - break; - } - } - op = CMP; - imm = 0; - break; - - case TCG_COND_LTU: - case TCG_COND_GEU: - case TCG_COND_LEU: - case TCG_COND_GTU: - if (const_arg2) { - if ((uint16_t) arg2 == arg2) { - op = CMPLI; - imm = 1; - break; - } - } - op = CMPL; - imm = 0; - break; - - default: - tcg_abort (); - } - op |= BF (cr); - - if (imm) - tcg_out32 (s, op | RA (arg1) | (arg2 & 0xffff)); - else { - if (const_arg2) { - tcg_out_movi (s, TCG_TYPE_I32, 0, arg2); - tcg_out32 (s, op | RA (arg1) | RB (0)); - } - else - tcg_out32 (s, op | RA (arg1) | RB (arg2)); - } - -} - -static void tcg_out_bc (TCGContext *s, int bc, int label_index) -{ - TCGLabel *l = &s->labels[label_index]; - - if (l->has_value) - tcg_out32 (s, bc | reloc_pc14_val (s->code_ptr, l->u.value)); - else { - uint16_t val = *(uint16_t *) &s->code_ptr[2]; - - /* Thanks to Andrzej Zaborowski */ - tcg_out32 (s, bc | (val & 0xfffc)); - tcg_out_reloc (s, s->code_ptr - 4, R_PPC_REL14, label_index, 0); - } -} - -static void tcg_out_brcond (TCGContext *s, int cond, - TCGArg arg1, TCGArg arg2, int const_arg2, - int label_index) -{ - tcg_out_cmp (s, cond, arg1, arg2, const_arg2, 7); - tcg_out_bc (s, tcg_to_bc[cond], label_index); -} - -/* XXX: we implement it at the target level to avoid having to - handle cross basic blocks temporaries */ -static void tcg_out_brcond2 (TCGContext *s, const TCGArg *args, - const int *const_args) -{ - int cond = args[4], label_index = args[5], op; - struct { int bit1; int bit2; int cond2; } bits[] = { - [TCG_COND_LT ] = { CR_LT, CR_LT, TCG_COND_LT }, - [TCG_COND_LE ] = { CR_LT, CR_GT, TCG_COND_LT }, - [TCG_COND_GT ] = { CR_GT, CR_GT, TCG_COND_GT }, - [TCG_COND_GE ] = { CR_GT, CR_LT, TCG_COND_GT }, - [TCG_COND_LTU] = { CR_LT, CR_LT, TCG_COND_LTU }, - [TCG_COND_LEU] = { CR_LT, CR_GT, TCG_COND_LTU }, - [TCG_COND_GTU] = { CR_GT, CR_GT, TCG_COND_GTU }, - [TCG_COND_GEU] = { CR_GT, CR_LT, TCG_COND_GTU }, - }, *b = &bits[cond]; - - switch (cond) { - case TCG_COND_EQ: - case TCG_COND_NE: - op = (cond == TCG_COND_EQ) ? CRAND : CRNAND; - tcg_out_cmp (s, cond, args[0], args[2], const_args[2], 6); - tcg_out_cmp (s, cond, args[1], args[3], const_args[3], 7); - tcg_out32 (s, op | BT (7, CR_EQ) | BA (6, CR_EQ) | BB (7, CR_EQ)); - break; - case TCG_COND_LT: - case TCG_COND_LE: - case TCG_COND_GT: - case TCG_COND_GE: - case TCG_COND_LTU: - case TCG_COND_LEU: - case TCG_COND_GTU: - case TCG_COND_GEU: - op = (b->bit1 != b->bit2) ? CRANDC : CRAND; - tcg_out_cmp (s, b->cond2, args[1], args[3], const_args[3], 5); - tcg_out_cmp (s, TCG_COND_EQ, args[1], args[3], const_args[3], 6); - tcg_out_cmp (s, cond, args[0], args[2], const_args[2], 7); - tcg_out32 (s, op | BT (7, CR_EQ) | BA (6, CR_EQ) | BB (7, b->bit2)); - tcg_out32 (s, CROR | BT (7, CR_EQ) | BA (5, b->bit1) | BB (7, CR_EQ)); - break; - default: - tcg_abort(); - } - - tcg_out_bc (s, (BC | BI (7, CR_EQ) | BO_COND_TRUE), label_index); -} - -void ppc_tb_set_jmp_target (unsigned long jmp_addr, unsigned long addr) -{ - uint32_t *ptr; - long disp = addr - jmp_addr; - unsigned long patch_size; - - ptr = (uint32_t *)jmp_addr; - - if ((disp << 6) >> 6 != disp) { - ptr[0] = 0x3c000000 | (addr >> 16); /* lis 0,addr@ha */ - ptr[1] = 0x60000000 | (addr & 0xffff); /* la 0,addr@l(0) */ - ptr[2] = 0x7c0903a6; /* mtctr 0 */ - ptr[3] = 0x4e800420; /* brctr */ - patch_size = 16; - } else { - /* patch the branch destination */ - if (disp != 16) { - *ptr = 0x48000000 | (disp & 0x03fffffc); /* b disp */ - patch_size = 4; - } else { - ptr[0] = 0x60000000; /* nop */ - ptr[1] = 0x60000000; - ptr[2] = 0x60000000; - ptr[3] = 0x60000000; - patch_size = 16; - } - } - /* flush icache */ - flush_icache_range(jmp_addr, jmp_addr + patch_size); -} - -static void tcg_out_op(TCGContext *s, int opc, const TCGArg *args, - const int *const_args) -{ - switch (opc) { - case INDEX_op_exit_tb: - tcg_out_movi (s, TCG_TYPE_I32, TCG_REG_R3, args[0]); - tcg_out_b (s, 0, (tcg_target_long) tb_ret_addr); - break; - case INDEX_op_goto_tb: - if (s->tb_jmp_offset) { - /* direct jump method */ - - s->tb_jmp_offset[args[0]] = s->code_ptr - s->code_buf; - s->code_ptr += 16; - } - else { - tcg_abort (); - } - s->tb_next_offset[args[0]] = s->code_ptr - s->code_buf; - break; - case INDEX_op_br: - { - TCGLabel *l = &s->labels[args[0]]; - - if (l->has_value) { - tcg_out_b (s, 0, l->u.value); - } - else { - uint32_t val = *(uint32_t *) s->code_ptr; - - /* Thanks to Andrzej Zaborowski */ - tcg_out32 (s, B | (val & 0x3fffffc)); - tcg_out_reloc (s, s->code_ptr - 4, R_PPC_REL24, args[0], 0); - } - } - break; - case INDEX_op_call: - tcg_out_call (s, args[0], const_args[0]); - break; - case INDEX_op_jmp: - if (const_args[0]) { - tcg_out_b (s, 0, args[0]); - } - else { - tcg_out32 (s, MTSPR | RS (args[0]) | CTR); - tcg_out32 (s, BCCTR | BO_ALWAYS); - } - break; - case INDEX_op_movi_i32: - tcg_out_movi(s, TCG_TYPE_I32, args[0], args[1]); - break; - case INDEX_op_ld8u_i32: - tcg_out_ldst (s, args[0], args[1], args[2], LBZ, LBZX); - break; - case INDEX_op_ld8s_i32: - tcg_out_ldst (s, args[0], args[1], args[2], LBZ, LBZX); - tcg_out32 (s, EXTSB | RS (args[0]) | RA (args[0])); - break; - case INDEX_op_ld16u_i32: - tcg_out_ldst (s, args[0], args[1], args[2], LHZ, LHZX); - break; - case INDEX_op_ld16s_i32: - tcg_out_ldst (s, args[0], args[1], args[2], LHA, LHAX); - break; - case INDEX_op_ld_i32: - tcg_out_ldst (s, args[0], args[1], args[2], LWZ, LWZX); - break; - case INDEX_op_st8_i32: - tcg_out_ldst (s, args[0], args[1], args[2], STB, STBX); - break; - case INDEX_op_st16_i32: - tcg_out_ldst (s, args[0], args[1], args[2], STH, STHX); - break; - case INDEX_op_st_i32: - tcg_out_ldst (s, args[0], args[1], args[2], STW, STWX); - break; - - case INDEX_op_add_i32: - if (const_args[2]) - ppc_addi (s, args[0], args[1], args[2]); - else - tcg_out32 (s, ADD | TAB (args[0], args[1], args[2])); - break; - case INDEX_op_sub_i32: - if (const_args[2]) - ppc_addi (s, args[0], args[1], -args[2]); - else - tcg_out32 (s, SUBF | TAB (args[0], args[2], args[1])); - break; - - case INDEX_op_and_i32: - if (const_args[2]) { - uint32_t c; - - c = args[2]; - - if (!c) { - tcg_out_movi (s, TCG_TYPE_I32, args[0], 0); - break; - } -#ifdef __PPU__ - uint32_t t, n; - int mb, me; - - n = c ^ -(c & 1); - t = n + (n & -n); - - if ((t & (t - 1)) == 0) { - int lzc, tzc; - - if ((c & 0x80000001) == 0x80000001) { - lzc = clz32 (n); - tzc = ctz32 (n); - - mb = 32 - tzc; - me = lzc - 1; - } - else { - lzc = clz32 (c); - tzc = ctz32 (c); - - mb = lzc; - me = 31 - tzc; - } - - tcg_out32 (s, (RLWINM - | RA (args[0]) - | RS (args[1]) - | SH (0) - | MB (mb) - | ME (me) - ) - ); - } - else -#endif /* !__PPU__ */ - { - if ((c & 0xffff) == c) - tcg_out32 (s, ANDI | RS (args[1]) | RA (args[0]) | c); - else if ((c & 0xffff0000) == c) - tcg_out32 (s, ANDIS | RS (args[1]) | RA (args[0]) - | ((c >> 16) & 0xffff)); - else { - tcg_out_movi (s, TCG_TYPE_I32, 0, c); - tcg_out32 (s, AND | SAB (args[1], args[0], 0)); - } - } - } - else - tcg_out32 (s, AND | SAB (args[1], args[0], args[2])); - break; - case INDEX_op_or_i32: - if (const_args[2]) { - if (args[2] & 0xffff) { - tcg_out32 (s, ORI | RS (args[1]) | RA (args[0]) - | (args[2] & 0xffff)); - if (args[2] >> 16) - tcg_out32 (s, ORIS | RS (args[0]) | RA (args[0]) - | ((args[2] >> 16) & 0xffff)); - } - else { - tcg_out32 (s, ORIS | RS (args[1]) | RA (args[0]) - | ((args[2] >> 16) & 0xffff)); - } - } - else - tcg_out32 (s, OR | SAB (args[1], args[0], args[2])); - break; - case INDEX_op_xor_i32: - if (const_args[2]) { - if ((args[2] & 0xffff) == args[2]) - tcg_out32 (s, XORI | RS (args[1]) | RA (args[0]) - | (args[2] & 0xffff)); - else if ((args[2] & 0xffff0000) == args[2]) - tcg_out32 (s, XORIS | RS (args[1]) | RA (args[0]) - | ((args[2] >> 16) & 0xffff)); - else { - tcg_out_movi (s, TCG_TYPE_I32, 0, args[2]); - tcg_out32 (s, XOR | SAB (args[1], args[0], 0)); - } - } - else - tcg_out32 (s, XOR | SAB (args[1], args[0], args[2])); - break; - - case INDEX_op_mul_i32: - if (const_args[2]) { - if (args[2] == (int16_t) args[2]) - tcg_out32 (s, MULLI | RT (args[0]) | RA (args[1]) - | (args[2] & 0xffff)); - else { - tcg_out_movi (s, TCG_TYPE_I32, 0, args[2]); - tcg_out32 (s, MULLW | TAB (args[0], args[1], 0)); - } - } - else - tcg_out32 (s, MULLW | TAB (args[0], args[1], args[2])); - break; - - case INDEX_op_div_i32: - tcg_out32 (s, DIVW | TAB (args[0], args[1], args[2])); - break; - - case INDEX_op_divu_i32: - tcg_out32 (s, DIVWU | TAB (args[0], args[1], args[2])); - break; - - case INDEX_op_rem_i32: - tcg_out32 (s, DIVW | TAB (0, args[1], args[2])); - tcg_out32 (s, MULLW | TAB (0, 0, args[2])); - tcg_out32 (s, SUBF | TAB (args[0], 0, args[1])); - break; - - case INDEX_op_remu_i32: - tcg_out32 (s, DIVWU | TAB (0, args[1], args[2])); - tcg_out32 (s, MULLW | TAB (0, 0, args[2])); - tcg_out32 (s, SUBF | TAB (args[0], 0, args[1])); - break; - - case INDEX_op_mulu2_i32: - if (args[0] == args[2] || args[0] == args[3]) { - tcg_out32 (s, MULLW | TAB (0, args[2], args[3])); - tcg_out32 (s, MULHWU | TAB (args[1], args[2], args[3])); - tcg_out_mov (s, args[0], 0); - } - else { - tcg_out32 (s, MULLW | TAB (args[0], args[2], args[3])); - tcg_out32 (s, MULHWU | TAB (args[1], args[2], args[3])); - } - break; - - case INDEX_op_shl_i32: - if (const_args[2]) { - tcg_out32 (s, (RLWINM - | RA (args[0]) - | RS (args[1]) - | SH (args[2]) - | MB (0) - | ME (31 - args[2]) - ) - ); - } - else - tcg_out32 (s, SLW | SAB (args[1], args[0], args[2])); - break; - case INDEX_op_shr_i32: - if (const_args[2]) { - tcg_out32 (s, (RLWINM - | RA (args[0]) - | RS (args[1]) - | SH (32 - args[2]) - | MB (args[2]) - | ME (31) - ) - ); - } - else - tcg_out32 (s, SRW | SAB (args[1], args[0], args[2])); - break; - case INDEX_op_sar_i32: - if (const_args[2]) - tcg_out32 (s, SRAWI | RS (args[1]) | RA (args[0]) | SH (args[2])); - else - tcg_out32 (s, SRAW | SAB (args[1], args[0], args[2])); - break; - - case INDEX_op_add2_i32: - if (args[0] == args[3] || args[0] == args[5]) { - tcg_out32 (s, ADDC | TAB (0, args[2], args[4])); - tcg_out32 (s, ADDE | TAB (args[1], args[3], args[5])); - tcg_out_mov (s, args[0], 0); - } - else { - tcg_out32 (s, ADDC | TAB (args[0], args[2], args[4])); - tcg_out32 (s, ADDE | TAB (args[1], args[3], args[5])); - } - break; - case INDEX_op_sub2_i32: - if (args[0] == args[3] || args[0] == args[5]) { - tcg_out32 (s, SUBFC | TAB (0, args[4], args[2])); - tcg_out32 (s, SUBFE | TAB (args[1], args[5], args[3])); - tcg_out_mov (s, args[0], 0); - } - else { - tcg_out32 (s, SUBFC | TAB (args[0], args[4], args[2])); - tcg_out32 (s, SUBFE | TAB (args[1], args[5], args[3])); - } - break; - - case INDEX_op_brcond_i32: - /* - args[0] = r0 - args[1] = r1 - args[2] = cond - args[3] = r1 is const - args[4] = label_index - */ - tcg_out_brcond (s, args[2], args[0], args[1], const_args[1], args[3]); - break; - case INDEX_op_brcond2_i32: - tcg_out_brcond2(s, args, const_args); - break; - - case INDEX_op_neg_i32: - tcg_out32 (s, NEG | RT (args[0]) | RA (args[1])); - break; - - case INDEX_op_qemu_ld8u: - tcg_out_qemu_ld(s, args, 0); - break; - case INDEX_op_qemu_ld8s: - tcg_out_qemu_ld(s, args, 0 | 4); - break; - case INDEX_op_qemu_ld16u: - tcg_out_qemu_ld(s, args, 1); - break; - case INDEX_op_qemu_ld16s: - tcg_out_qemu_ld(s, args, 1 | 4); - break; - case INDEX_op_qemu_ld32u: - tcg_out_qemu_ld(s, args, 2); - break; - case INDEX_op_qemu_ld64: - tcg_out_qemu_ld(s, args, 3); - break; - case INDEX_op_qemu_st8: - tcg_out_qemu_st(s, args, 0); - break; - case INDEX_op_qemu_st16: - tcg_out_qemu_st(s, args, 1); - break; - case INDEX_op_qemu_st32: - tcg_out_qemu_st(s, args, 2); - break; - case INDEX_op_qemu_st64: - tcg_out_qemu_st(s, args, 3); - break; - - case INDEX_op_ext8s_i32: - tcg_out32 (s, EXTSB | RS (args[1]) | RA (args[0])); - break; - case INDEX_op_ext16s_i32: - tcg_out32 (s, EXTSH | RS (args[1]) | RA (args[0])); - break; - - default: - tcg_dump_ops (s, stderr); - tcg_abort (); - } -} - -static const TCGTargetOpDef ppc_op_defs[] = { - { INDEX_op_exit_tb, { } }, - { INDEX_op_goto_tb, { } }, - { INDEX_op_call, { "ri" } }, - { INDEX_op_jmp, { "ri" } }, - { INDEX_op_br, { } }, - - { INDEX_op_mov_i32, { "r", "r" } }, - { INDEX_op_movi_i32, { "r" } }, - { INDEX_op_ld8u_i32, { "r", "r" } }, - { INDEX_op_ld8s_i32, { "r", "r" } }, - { INDEX_op_ld16u_i32, { "r", "r" } }, - { INDEX_op_ld16s_i32, { "r", "r" } }, - { INDEX_op_ld_i32, { "r", "r" } }, - { INDEX_op_st8_i32, { "r", "r" } }, - { INDEX_op_st16_i32, { "r", "r" } }, - { INDEX_op_st_i32, { "r", "r" } }, - - { INDEX_op_add_i32, { "r", "r", "ri" } }, - { INDEX_op_mul_i32, { "r", "r", "ri" } }, - { INDEX_op_div_i32, { "r", "r", "r" } }, - { INDEX_op_divu_i32, { "r", "r", "r" } }, - { INDEX_op_rem_i32, { "r", "r", "r" } }, - { INDEX_op_remu_i32, { "r", "r", "r" } }, - { INDEX_op_mulu2_i32, { "r", "r", "r", "r" } }, - { INDEX_op_sub_i32, { "r", "r", "ri" } }, - { INDEX_op_and_i32, { "r", "r", "ri" } }, - { INDEX_op_or_i32, { "r", "r", "ri" } }, - { INDEX_op_xor_i32, { "r", "r", "ri" } }, - - { INDEX_op_shl_i32, { "r", "r", "ri" } }, - { INDEX_op_shr_i32, { "r", "r", "ri" } }, - { INDEX_op_sar_i32, { "r", "r", "ri" } }, - - { INDEX_op_brcond_i32, { "r", "ri" } }, - - { INDEX_op_add2_i32, { "r", "r", "r", "r", "r", "r" } }, - { INDEX_op_sub2_i32, { "r", "r", "r", "r", "r", "r" } }, - { INDEX_op_brcond2_i32, { "r", "r", "r", "r" } }, - - { INDEX_op_neg_i32, { "r", "r" } }, - -#if TARGET_LONG_BITS == 32 - { INDEX_op_qemu_ld8u, { "r", "L" } }, - { INDEX_op_qemu_ld8s, { "r", "L" } }, - { INDEX_op_qemu_ld16u, { "r", "L" } }, - { INDEX_op_qemu_ld16s, { "r", "L" } }, - { INDEX_op_qemu_ld32u, { "r", "L" } }, - { INDEX_op_qemu_ld32s, { "r", "L" } }, - { INDEX_op_qemu_ld64, { "r", "r", "L" } }, - - { INDEX_op_qemu_st8, { "K", "K" } }, - { INDEX_op_qemu_st16, { "K", "K" } }, - { INDEX_op_qemu_st32, { "K", "K" } }, - { INDEX_op_qemu_st64, { "M", "M", "M" } }, -#else - { INDEX_op_qemu_ld8u, { "r", "L", "L" } }, - { INDEX_op_qemu_ld8s, { "r", "L", "L" } }, - { INDEX_op_qemu_ld16u, { "r", "L", "L" } }, - { INDEX_op_qemu_ld16s, { "r", "L", "L" } }, - { INDEX_op_qemu_ld32u, { "r", "L", "L" } }, - { INDEX_op_qemu_ld32s, { "r", "L", "L" } }, - { INDEX_op_qemu_ld64, { "r", "L", "L", "L" } }, - - { INDEX_op_qemu_st8, { "K", "K", "K" } }, - { INDEX_op_qemu_st16, { "K", "K", "K" } }, - { INDEX_op_qemu_st32, { "K", "K", "K" } }, - { INDEX_op_qemu_st64, { "M", "M", "M", "M" } }, -#endif - - { INDEX_op_ext8s_i32, { "r", "r" } }, - { INDEX_op_ext16s_i32, { "r", "r" } }, - - { -1 }, -}; - -void tcg_target_init(TCGContext *s) -{ - tcg_regset_set32(tcg_target_available_regs[TCG_TYPE_I32], 0, 0xffffffff); - tcg_regset_set32(tcg_target_call_clobber_regs, 0, - (1 << TCG_REG_R0) | -#ifdef __APPLE__ - (1 << TCG_REG_R2) | -#endif - (1 << TCG_REG_R3) | - (1 << TCG_REG_R4) | - (1 << TCG_REG_R5) | - (1 << TCG_REG_R6) | - (1 << TCG_REG_R7) | - (1 << TCG_REG_R8) | - (1 << TCG_REG_R9) | - (1 << TCG_REG_R10) | - (1 << TCG_REG_R11) | - (1 << TCG_REG_R12) - ); - - tcg_regset_clear(s->reserved_regs); - tcg_regset_set_reg(s->reserved_regs, TCG_REG_R0); - tcg_regset_set_reg(s->reserved_regs, TCG_REG_R1); -#ifndef __APPLE__ - tcg_regset_set_reg(s->reserved_regs, TCG_REG_R2); -#endif -#ifdef __linux__ - tcg_regset_set_reg(s->reserved_regs, TCG_REG_R13); -#endif -#ifdef CONFIG_USE_GUEST_BASE - tcg_regset_set_reg(s->reserved_regs, TCG_GUEST_BASE_REG); -#endif - - tcg_add_target_add_op_defs(ppc_op_defs); -} diff --git a/qemu/qemu-git/tcg/ppc/.svn/text-base/tcg-target.h.svn-base b/qemu/qemu-git/tcg/ppc/.svn/text-base/tcg-target.h.svn-base deleted file mode 100644 index 0197e79..0000000 --- a/qemu/qemu-git/tcg/ppc/.svn/text-base/tcg-target.h.svn-base +++ /dev/null @@ -1,89 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2008 Fabrice Bellard - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ -#define TCG_TARGET_PPC 1 - -#define TCG_TARGET_REG_BITS 32 -#define TCG_TARGET_WORDS_BIGENDIAN -#define TCG_TARGET_NB_REGS 32 - -enum { - TCG_REG_R0 = 0, - TCG_REG_R1, - TCG_REG_R2, - TCG_REG_R3, - TCG_REG_R4, - TCG_REG_R5, - TCG_REG_R6, - TCG_REG_R7, - TCG_REG_R8, - TCG_REG_R9, - TCG_REG_R10, - TCG_REG_R11, - TCG_REG_R12, - TCG_REG_R13, - TCG_REG_R14, - TCG_REG_R15, - TCG_REG_R16, - TCG_REG_R17, - TCG_REG_R18, - TCG_REG_R19, - TCG_REG_R20, - TCG_REG_R21, - TCG_REG_R22, - TCG_REG_R23, - TCG_REG_R24, - TCG_REG_R25, - TCG_REG_R26, - TCG_REG_R27, - TCG_REG_R28, - TCG_REG_R29, - TCG_REG_R30, - TCG_REG_R31 -}; - -/* used for function call generation */ -#define TCG_REG_CALL_STACK TCG_REG_R1 -#define TCG_TARGET_STACK_ALIGN 16 -#if defined __APPLE__ -#define TCG_TARGET_CALL_STACK_OFFSET 24 -#elif defined _AIX -#define TCG_TARGET_CALL_STACK_OFFSET 52 -#elif defined __linux__ -#define TCG_TARGET_CALL_ALIGN_ARGS 1 -#define TCG_TARGET_CALL_STACK_OFFSET 8 -#else -#error Unsupported system -#endif - -/* optional instructions */ -#define TCG_TARGET_HAS_neg_i32 -#define TCG_TARGET_HAS_div_i32 -#define TCG_TARGET_HAS_ext8s_i32 -#define TCG_TARGET_HAS_ext16s_i32 - -#define TCG_AREG0 TCG_REG_R27 -#define TCG_AREG1 TCG_REG_R24 -#define TCG_AREG2 TCG_REG_R25 - -#define TCG_TARGET_HAS_GUEST_BASE diff --git a/qemu/qemu-git/tcg/ppc64/.svn/all-wcprops b/qemu/qemu-git/tcg/ppc64/.svn/all-wcprops deleted file mode 100644 index 283c770..0000000 --- a/qemu/qemu-git/tcg/ppc64/.svn/all-wcprops +++ /dev/null @@ -1,17 +0,0 @@ -K 25 -svn:wc:ra_dav:version-url -V 49 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/ppc64 -END -tcg-target.c -K 25 -svn:wc:ra_dav:version-url -V 62 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/ppc64/tcg-target.c -END -tcg-target.h -K 25 -svn:wc:ra_dav:version-url -V 62 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/ppc64/tcg-target.h -END diff --git a/qemu/qemu-git/tcg/ppc64/.svn/entries b/qemu/qemu-git/tcg/ppc64/.svn/entries deleted file mode 100644 index d5aae10..0000000 --- a/qemu/qemu-git/tcg/ppc64/.svn/entries +++ /dev/null @@ -1,96 +0,0 @@ -10 - -dir -11 -http://svn.code.sf.net/p/x49gp/code/qemu/qemu-git/tcg/ppc64 -http://svn.code.sf.net/p/x49gp/code - - - -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - -481df3bd-3408-496c-b7de-451e46197bb5 - -tcg-target.c -file - - - - -2013-08-23T00:54:47.000000Z -89a4d5db0bf452bffd14e2d50214d6b6 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -44198 - -tcg-target.h -file - - - - -2013-08-23T00:54:47.000000Z -0e7b6224bdda2c765280c10fdb2372a1 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -2427 - diff --git a/qemu/qemu-git/tcg/ppc64/.svn/text-base/tcg-target.c.svn-base b/qemu/qemu-git/tcg/ppc64/.svn/text-base/tcg-target.c.svn-base deleted file mode 100644 index 803db48..0000000 --- a/qemu/qemu-git/tcg/ppc64/.svn/text-base/tcg-target.c.svn-base +++ /dev/null @@ -1,1570 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2008 Fabrice Bellard - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ - -#define TCG_CT_CONST_U32 0x100 - -static uint8_t *tb_ret_addr; - -#define FAST_PATH - -#if TARGET_PHYS_ADDR_BITS == 32 -#define LD_ADDEND LWZ -#else -#define LD_ADDEND LD -#endif - -#if TARGET_LONG_BITS == 32 -#define LD_ADDR LWZU -#define CMP_L 0 -#else -#define LD_ADDR LDU -#define CMP_L (1<<21) -#endif - -#ifndef GUEST_BASE -#define GUEST_BASE 0 -#endif - -#ifdef CONFIG_USE_GUEST_BASE -#define TCG_GUEST_BASE_REG 30 -#else -#define TCG_GUEST_BASE_REG 0 -#endif - -#ifndef NDEBUG -static const char * const tcg_target_reg_names[TCG_TARGET_NB_REGS] = { - "r0", - "r1", - "rp", - "r3", - "r4", - "r5", - "r6", - "r7", - "r8", - "r9", - "r10", - "r11", - "r12", - "r13", - "r14", - "r15", - "r16", - "r17", - "r18", - "r19", - "r20", - "r21", - "r22", - "r23", - "r24", - "r25", - "r26", - "r27", - "r28", - "r29", - "r30", - "r31" -}; -#endif - -static const int tcg_target_reg_alloc_order[] = { - TCG_REG_R14, - TCG_REG_R15, - TCG_REG_R16, - TCG_REG_R17, - TCG_REG_R18, - TCG_REG_R19, - TCG_REG_R20, - TCG_REG_R21, - TCG_REG_R22, - TCG_REG_R23, - TCG_REG_R28, - TCG_REG_R29, - TCG_REG_R30, - TCG_REG_R31, -#ifdef __APPLE__ - TCG_REG_R2, -#endif - TCG_REG_R3, - TCG_REG_R4, - TCG_REG_R5, - TCG_REG_R6, - TCG_REG_R7, - TCG_REG_R8, - TCG_REG_R9, - TCG_REG_R10, -#ifndef __APPLE__ - TCG_REG_R11, -#endif - TCG_REG_R12, - TCG_REG_R24, - TCG_REG_R25, - TCG_REG_R26, - TCG_REG_R27 -}; - -static const int tcg_target_call_iarg_regs[] = { - TCG_REG_R3, - TCG_REG_R4, - TCG_REG_R5, - TCG_REG_R6, - TCG_REG_R7, - TCG_REG_R8, - TCG_REG_R9, - TCG_REG_R10 -}; - -static const int tcg_target_call_oarg_regs[2] = { - TCG_REG_R3 -}; - -static const int tcg_target_callee_save_regs[] = { -#ifdef __APPLE__ - TCG_REG_R11, -#endif - TCG_REG_R14, - TCG_REG_R15, - TCG_REG_R16, - TCG_REG_R17, - TCG_REG_R18, - TCG_REG_R19, - TCG_REG_R20, - TCG_REG_R21, - TCG_REG_R22, - TCG_REG_R23, - TCG_REG_R24, - TCG_REG_R25, - TCG_REG_R26, - /* TCG_REG_R27, */ /* currently used for the global env, so no - need to save */ - TCG_REG_R28, - TCG_REG_R29, - TCG_REG_R30, - TCG_REG_R31 -}; - -static uint32_t reloc_pc24_val (void *pc, tcg_target_long target) -{ - tcg_target_long disp; - - disp = target - (tcg_target_long) pc; - if ((disp << 38) >> 38 != disp) - tcg_abort (); - - return disp & 0x3fffffc; -} - -static void reloc_pc24 (void *pc, tcg_target_long target) -{ - *(uint32_t *) pc = (*(uint32_t *) pc & ~0x3fffffc) - | reloc_pc24_val (pc, target); -} - -static uint16_t reloc_pc14_val (void *pc, tcg_target_long target) -{ - tcg_target_long disp; - - disp = target - (tcg_target_long) pc; - if (disp != (int16_t) disp) - tcg_abort (); - - return disp & 0xfffc; -} - -static void reloc_pc14 (void *pc, tcg_target_long target) -{ - *(uint32_t *) pc = (*(uint32_t *) pc & ~0xfffc) - | reloc_pc14_val (pc, target); -} - -static void patch_reloc (uint8_t *code_ptr, int type, - tcg_target_long value, tcg_target_long addend) -{ - value += addend; - switch (type) { - case R_PPC_REL14: - reloc_pc14 (code_ptr, value); - break; - case R_PPC_REL24: - reloc_pc24 (code_ptr, value); - break; - default: - tcg_abort (); - } -} - -/* maximum number of register used for input function arguments */ -static int tcg_target_get_call_iarg_regs_count (int flags) -{ - return ARRAY_SIZE (tcg_target_call_iarg_regs); -} - -/* parse target specific constraints */ -static int target_parse_constraint (TCGArgConstraint *ct, const char **pct_str) -{ - const char *ct_str; - - ct_str = *pct_str; - switch (ct_str[0]) { - case 'A': case 'B': case 'C': case 'D': - ct->ct |= TCG_CT_REG; - tcg_regset_set_reg (ct->u.regs, 3 + ct_str[0] - 'A'); - break; - case 'r': - ct->ct |= TCG_CT_REG; - tcg_regset_set32 (ct->u.regs, 0, 0xffffffff); - break; - case 'L': /* qemu_ld constraint */ - ct->ct |= TCG_CT_REG; - tcg_regset_set32 (ct->u.regs, 0, 0xffffffff); - tcg_regset_reset_reg (ct->u.regs, TCG_REG_R3); -#ifdef CONFIG_SOFTMMU - tcg_regset_reset_reg (ct->u.regs, TCG_REG_R4); -#endif - break; - case 'S': /* qemu_st constraint */ - ct->ct |= TCG_CT_REG; - tcg_regset_set32 (ct->u.regs, 0, 0xffffffff); - tcg_regset_reset_reg (ct->u.regs, TCG_REG_R3); -#ifdef CONFIG_SOFTMMU - tcg_regset_reset_reg (ct->u.regs, TCG_REG_R4); - tcg_regset_reset_reg (ct->u.regs, TCG_REG_R5); -#endif - break; - case 'Z': - ct->ct |= TCG_CT_CONST_U32; - break; - default: - return -1; - } - ct_str++; - *pct_str = ct_str; - return 0; -} - -/* test if a constant matches the constraint */ -static int tcg_target_const_match (tcg_target_long val, - const TCGArgConstraint *arg_ct) -{ - int ct; - - ct = arg_ct->ct; - if (ct & TCG_CT_CONST) - return 1; - else if ((ct & TCG_CT_CONST_U32) && (val == (uint32_t) val)) - return 1; - return 0; -} - -#define OPCD(opc) ((opc)<<26) -#define XO19(opc) (OPCD(19)|((opc)<<1)) -#define XO30(opc) (OPCD(30)|((opc)<<2)) -#define XO31(opc) (OPCD(31)|((opc)<<1)) -#define XO58(opc) (OPCD(58)|(opc)) -#define XO62(opc) (OPCD(62)|(opc)) - -#define B OPCD( 18) -#define BC OPCD( 16) -#define LBZ OPCD( 34) -#define LHZ OPCD( 40) -#define LHA OPCD( 42) -#define LWZ OPCD( 32) -#define STB OPCD( 38) -#define STH OPCD( 44) -#define STW OPCD( 36) - -#define STD XO62( 0) -#define STDU XO62( 1) -#define STDX XO31(149) - -#define LD XO58( 0) -#define LDX XO31( 21) -#define LDU XO58( 1) -#define LWA XO58( 2) -#define LWAX XO31(341) - -#define ADDI OPCD( 14) -#define ADDIS OPCD( 15) -#define ORI OPCD( 24) -#define ORIS OPCD( 25) -#define XORI OPCD( 26) -#define XORIS OPCD( 27) -#define ANDI OPCD( 28) -#define ANDIS OPCD( 29) -#define MULLI OPCD( 7) -#define CMPLI OPCD( 10) -#define CMPI OPCD( 11) - -#define LWZU OPCD( 33) -#define STWU OPCD( 37) - -#define RLWINM OPCD( 21) - -#define RLDICL XO30( 0) -#define RLDICR XO30( 1) -#define RLDIMI XO30( 3) - -#define BCLR XO19( 16) -#define BCCTR XO19(528) -#define CRAND XO19(257) -#define CRANDC XO19(129) -#define CRNAND XO19(225) -#define CROR XO19(449) - -#define EXTSB XO31(954) -#define EXTSH XO31(922) -#define EXTSW XO31(986) -#define ADD XO31(266) -#define ADDE XO31(138) -#define ADDC XO31( 10) -#define AND XO31( 28) -#define SUBF XO31( 40) -#define SUBFC XO31( 8) -#define SUBFE XO31(136) -#define OR XO31(444) -#define XOR XO31(316) -#define MULLW XO31(235) -#define MULHWU XO31( 11) -#define DIVW XO31(491) -#define DIVWU XO31(459) -#define CMP XO31( 0) -#define CMPL XO31( 32) -#define LHBRX XO31(790) -#define LWBRX XO31(534) -#define STHBRX XO31(918) -#define STWBRX XO31(662) -#define MFSPR XO31(339) -#define MTSPR XO31(467) -#define SRAWI XO31(824) -#define NEG XO31(104) - -#define MULLD XO31(233) -#define MULHD XO31( 73) -#define MULHDU XO31( 9) -#define DIVD XO31(489) -#define DIVDU XO31(457) - -#define LBZX XO31( 87) -#define LHZX XO31(279) -#define LHAX XO31(343) -#define LWZX XO31( 23) -#define STBX XO31(215) -#define STHX XO31(407) -#define STWX XO31(151) - -#define SPR(a,b) ((((a)<<5)|(b))<<11) -#define LR SPR(8, 0) -#define CTR SPR(9, 0) - -#define SLW XO31( 24) -#define SRW XO31(536) -#define SRAW XO31(792) - -#define SLD XO31( 27) -#define SRD XO31(539) -#define SRAD XO31(794) -#define SRADI XO31(413<<1) - -#define TW XO31( 4) -#define TRAP (TW | TO (31)) - -#define RT(r) ((r)<<21) -#define RS(r) ((r)<<21) -#define RA(r) ((r)<<16) -#define RB(r) ((r)<<11) -#define TO(t) ((t)<<21) -#define SH(s) ((s)<<11) -#define MB(b) ((b)<<6) -#define ME(e) ((e)<<1) -#define BO(o) ((o)<<21) -#define MB64(b) ((b)<<5) - -#define LK 1 - -#define TAB(t,a,b) (RT(t) | RA(a) | RB(b)) -#define SAB(s,a,b) (RS(s) | RA(a) | RB(b)) - -#define BF(n) ((n)<<23) -#define BI(n, c) (((c)+((n)*4))<<16) -#define BT(n, c) (((c)+((n)*4))<<21) -#define BA(n, c) (((c)+((n)*4))<<16) -#define BB(n, c) (((c)+((n)*4))<<11) - -#define BO_COND_TRUE BO (12) -#define BO_COND_FALSE BO ( 4) -#define BO_ALWAYS BO (20) - -enum { - CR_LT, - CR_GT, - CR_EQ, - CR_SO -}; - -static const uint32_t tcg_to_bc[10] = { - [TCG_COND_EQ] = BC | BI (7, CR_EQ) | BO_COND_TRUE, - [TCG_COND_NE] = BC | BI (7, CR_EQ) | BO_COND_FALSE, - [TCG_COND_LT] = BC | BI (7, CR_LT) | BO_COND_TRUE, - [TCG_COND_GE] = BC | BI (7, CR_LT) | BO_COND_FALSE, - [TCG_COND_LE] = BC | BI (7, CR_GT) | BO_COND_FALSE, - [TCG_COND_GT] = BC | BI (7, CR_GT) | BO_COND_TRUE, - [TCG_COND_LTU] = BC | BI (7, CR_LT) | BO_COND_TRUE, - [TCG_COND_GEU] = BC | BI (7, CR_LT) | BO_COND_FALSE, - [TCG_COND_LEU] = BC | BI (7, CR_GT) | BO_COND_FALSE, - [TCG_COND_GTU] = BC | BI (7, CR_GT) | BO_COND_TRUE, -}; - -static void tcg_out_mov (TCGContext *s, int ret, int arg) -{ - tcg_out32 (s, OR | SAB (arg, ret, arg)); -} - -static void tcg_out_rld (TCGContext *s, int op, int ra, int rs, int sh, int mb) -{ - sh = SH (sh & 0x1f) | (((sh >> 5) & 1) << 1); - mb = MB64 ((mb >> 5) | ((mb << 1) & 0x3f)); - tcg_out32 (s, op | RA (ra) | RS (rs) | sh | mb); -} - -static void tcg_out_movi32 (TCGContext *s, int ret, int32_t arg) -{ - if (arg == (int16_t) arg) - tcg_out32 (s, ADDI | RT (ret) | RA (0) | (arg & 0xffff)); - else { - tcg_out32 (s, ADDIS | RT (ret) | RA (0) | ((arg >> 16) & 0xffff)); - if (arg & 0xffff) - tcg_out32 (s, ORI | RS (ret) | RA (ret) | (arg & 0xffff)); - } -} - -static void tcg_out_movi (TCGContext *s, TCGType type, - int ret, tcg_target_long arg) -{ - int32_t arg32 = arg; - arg = type == TCG_TYPE_I32 ? arg & 0xffffffff : arg; - - if (arg == arg32) { - tcg_out_movi32 (s, ret, arg32); - } - else { - if ((uint64_t) arg >> 32) { - uint16_t h16 = arg >> 16; - uint16_t l16 = arg; - - tcg_out_movi32 (s, ret, arg >> 32); - tcg_out_rld (s, RLDICR, ret, ret, 32, 31); - if (h16) tcg_out32 (s, ORIS | RS (ret) | RA (ret) | h16); - if (l16) tcg_out32 (s, ORI | RS (ret) | RA (ret) | l16); - } - else { - tcg_out_movi32 (s, ret, arg32); - if (arg32 < 0) - tcg_out_rld (s, RLDICL, ret, ret, 0, 32); - } - } -} - -static void tcg_out_b (TCGContext *s, int mask, tcg_target_long target) -{ - tcg_target_long disp; - - disp = target - (tcg_target_long) s->code_ptr; - if ((disp << 38) >> 38 == disp) - tcg_out32 (s, B | (disp & 0x3fffffc) | mask); - else { - tcg_out_movi (s, TCG_TYPE_I64, 0, (tcg_target_long) target); - tcg_out32 (s, MTSPR | RS (0) | CTR); - tcg_out32 (s, BCCTR | BO_ALWAYS | mask); - } -} - -static void tcg_out_call (TCGContext *s, tcg_target_long arg, int const_arg) -{ -#ifdef __APPLE__ - if (const_arg) { - tcg_out_b (s, LK, arg); - } - else { - tcg_out32 (s, MTSPR | RS (arg) | LR); - tcg_out32 (s, BCLR | BO_ALWAYS | LK); - } -#else - int reg; - - if (const_arg) { - reg = 2; - tcg_out_movi (s, TCG_TYPE_I64, reg, arg); - } - else reg = arg; - - tcg_out32 (s, LD | RT (0) | RA (reg)); - tcg_out32 (s, MTSPR | RA (0) | CTR); - tcg_out32 (s, LD | RT (11) | RA (reg) | 16); - tcg_out32 (s, LD | RT (2) | RA (reg) | 8); - tcg_out32 (s, BCCTR | BO_ALWAYS | LK); -#endif -} - -static void tcg_out_ldst (TCGContext *s, int ret, int addr, - int offset, int op1, int op2) -{ - if (offset == (int16_t) offset) - tcg_out32 (s, op1 | RT (ret) | RA (addr) | (offset & 0xffff)); - else { - tcg_out_movi (s, TCG_TYPE_I64, 0, offset); - tcg_out32 (s, op2 | RT (ret) | RA (addr) | RB (0)); - } -} - -static void tcg_out_ldsta (TCGContext *s, int ret, int addr, - int offset, int op1, int op2) -{ - if (offset == (int16_t) (offset & ~3)) - tcg_out32 (s, op1 | RT (ret) | RA (addr) | (offset & 0xffff)); - else { - tcg_out_movi (s, TCG_TYPE_I64, 0, offset); - tcg_out32 (s, op2 | RT (ret) | RA (addr) | RB (0)); - } -} - -#if defined (CONFIG_SOFTMMU) - -#include "../../softmmu_defs.h" - -static void *qemu_ld_helpers[4] = { - __ldb_mmu, - __ldw_mmu, - __ldl_mmu, - __ldq_mmu, -}; - -static void *qemu_st_helpers[4] = { - __stb_mmu, - __stw_mmu, - __stl_mmu, - __stq_mmu, -}; - -static void tcg_out_tlb_read (TCGContext *s, int r0, int r1, int r2, - int addr_reg, int s_bits, int offset) -{ -#if TARGET_LONG_BITS == 32 - tcg_out_rld (s, RLDICL, addr_reg, addr_reg, 0, 32); - - tcg_out32 (s, (RLWINM - | RA (r0) - | RS (addr_reg) - | SH (32 - (TARGET_PAGE_BITS - CPU_TLB_ENTRY_BITS)) - | MB (32 - (CPU_TLB_BITS + CPU_TLB_ENTRY_BITS)) - | ME (31 - CPU_TLB_ENTRY_BITS) - ) - ); - tcg_out32 (s, ADD | RT (r0) | RA (r0) | RB (TCG_AREG0)); - tcg_out32 (s, (LWZU | RT (r1) | RA (r0) | offset)); - tcg_out32 (s, (RLWINM - | RA (r2) - | RS (addr_reg) - | SH (0) - | MB ((32 - s_bits) & 31) - | ME (31 - TARGET_PAGE_BITS) - ) - ); -#else - tcg_out_rld (s, RLDICL, r0, addr_reg, - 64 - TARGET_PAGE_BITS, - 64 - CPU_TLB_BITS); - tcg_out_rld (s, RLDICR, r0, r0, - CPU_TLB_ENTRY_BITS, - 63 - CPU_TLB_ENTRY_BITS); - - tcg_out32 (s, ADD | TAB (r0, r0, TCG_AREG0)); - tcg_out32 (s, LD_ADDR | RT (r1) | RA (r0) | offset); - - if (!s_bits) { - tcg_out_rld (s, RLDICR, r2, addr_reg, 0, 63 - TARGET_PAGE_BITS); - } - else { - tcg_out_rld (s, RLDICL, r2, addr_reg, - 64 - TARGET_PAGE_BITS, - TARGET_PAGE_BITS - s_bits); - tcg_out_rld (s, RLDICL, r2, r2, TARGET_PAGE_BITS, 0); - } -#endif -} -#endif - -static void tcg_out_qemu_ld (TCGContext *s, const TCGArg *args, int opc) -{ - int addr_reg, data_reg, r0, r1, rbase, mem_index, s_bits, bswap; -#ifdef CONFIG_SOFTMMU - int r2; - void *label1_ptr, *label2_ptr; -#endif - - data_reg = *args++; - addr_reg = *args++; - mem_index = *args; - s_bits = opc & 3; - -#ifdef CONFIG_SOFTMMU - r0 = 3; - r1 = 4; - r2 = 0; - rbase = 0; - - tcg_out_tlb_read (s, r0, r1, r2, addr_reg, s_bits, - offsetof (CPUState, tlb_table[mem_index][0].addr_read)); - - tcg_out32 (s, CMP | BF (7) | RA (r2) | RB (r1) | CMP_L); - - label1_ptr = s->code_ptr; -#ifdef FAST_PATH - tcg_out32 (s, BC | BI (7, CR_EQ) | BO_COND_TRUE); -#endif - - /* slow path */ - tcg_out_mov (s, 3, addr_reg); - tcg_out_movi (s, TCG_TYPE_I64, 4, mem_index); - - tcg_out_call (s, (tcg_target_long) qemu_ld_helpers[s_bits], 1); - - switch (opc) { - case 0|4: - tcg_out32 (s, EXTSB | RA (data_reg) | RS (3)); - break; - case 1|4: - tcg_out32 (s, EXTSH | RA (data_reg) | RS (3)); - break; - case 2|4: - tcg_out32 (s, EXTSW | RA (data_reg) | RS (3)); - break; - case 0: - case 1: - case 2: - case 3: - if (data_reg != 3) - tcg_out_mov (s, data_reg, 3); - break; - } - label2_ptr = s->code_ptr; - tcg_out32 (s, B); - - /* label1: fast path */ -#ifdef FAST_PATH - reloc_pc14 (label1_ptr, (tcg_target_long) s->code_ptr); -#endif - - /* r0 now contains &env->tlb_table[mem_index][index].addr_read */ - tcg_out32 (s, (LD_ADDEND - | RT (r0) - | RA (r0) - | (offsetof (CPUTLBEntry, addend) - - offsetof (CPUTLBEntry, addr_read)) - )); - /* r0 = env->tlb_table[mem_index][index].addend */ - tcg_out32 (s, ADD | RT (r0) | RA (r0) | RB (addr_reg)); - /* r0 = env->tlb_table[mem_index][index].addend + addr */ - -#else /* !CONFIG_SOFTMMU */ -#if TARGET_LONG_BITS == 32 - tcg_out_rld (s, RLDICL, addr_reg, addr_reg, 0, 32); -#endif - r0 = addr_reg; - r1 = 3; - rbase = GUEST_BASE ? TCG_GUEST_BASE_REG : 0; -#endif - -#ifdef TARGET_WORDS_BIGENDIAN - bswap = 0; -#else - bswap = 1; -#endif - switch (opc) { - default: - case 0: - tcg_out32 (s, LBZX | TAB (data_reg, rbase, r0)); - break; - case 0|4: - tcg_out32 (s, LBZX | TAB (data_reg, rbase, r0)); - tcg_out32 (s, EXTSB | RA (data_reg) | RS (data_reg)); - break; - case 1: - if (bswap) - tcg_out32 (s, LHBRX | TAB (data_reg, rbase, r0)); - else - tcg_out32 (s, LHZX | TAB (data_reg, rbase, r0)); - break; - case 1|4: - if (bswap) { - tcg_out32 (s, LHBRX | TAB (data_reg, rbase, r0)); - tcg_out32 (s, EXTSH | RA (data_reg) | RS (data_reg)); - } - else tcg_out32 (s, LHAX | TAB (data_reg, rbase, r0)); - break; - case 2: - if (bswap) - tcg_out32 (s, LWBRX | TAB (data_reg, rbase, r0)); - else - tcg_out32 (s, LWZX | TAB (data_reg, rbase, r0)); - break; - case 2|4: - if (bswap) { - tcg_out32 (s, LWBRX | TAB (data_reg, rbase, r0)); - tcg_out32 (s, EXTSW | RA (data_reg) | RS (data_reg)); - } - else tcg_out32 (s, LWAX | TAB (data_reg, rbase, r0)); - break; - case 3: -#ifdef CONFIG_USE_GUEST_BASE - if (bswap) { - tcg_out32 (s, ADDI | RT (r1) | RA (r0) | 4); - tcg_out32 (s, LWBRX | TAB (data_reg, rbase, r0)); - tcg_out32 (s, LWBRX | TAB ( r1, rbase, r1)); - tcg_out_rld (s, RLDIMI, data_reg, r1, 32, 0); - } - else tcg_out32 (s, LDX | TAB (data_reg, rbase, r0)); -#else - if (bswap) { - tcg_out_movi32 (s, 0, 4); - tcg_out32 (s, LWBRX | RT (data_reg) | RB (r0)); - tcg_out32 (s, LWBRX | RT ( r1) | RA (r0)); - tcg_out_rld (s, RLDIMI, data_reg, r1, 32, 0); - } - else tcg_out32 (s, LD | RT (data_reg) | RA (r0)); -#endif - break; - } - -#ifdef CONFIG_SOFTMMU - reloc_pc24 (label2_ptr, (tcg_target_long) s->code_ptr); -#endif -} - -static void tcg_out_qemu_st (TCGContext *s, const TCGArg *args, int opc) -{ - int addr_reg, r0, r1, rbase, data_reg, mem_index, bswap; -#ifdef CONFIG_SOFTMMU - int r2; - void *label1_ptr, *label2_ptr; -#endif - - data_reg = *args++; - addr_reg = *args++; - mem_index = *args; - -#ifdef CONFIG_SOFTMMU - r0 = 3; - r1 = 4; - r2 = 0; - rbase = 0; - - tcg_out_tlb_read (s, r0, r1, r2, addr_reg, opc, - offsetof (CPUState, tlb_table[mem_index][0].addr_write)); - - tcg_out32 (s, CMP | BF (7) | RA (r2) | RB (r1) | CMP_L); - - label1_ptr = s->code_ptr; -#ifdef FAST_PATH - tcg_out32 (s, BC | BI (7, CR_EQ) | BO_COND_TRUE); -#endif - - /* slow path */ - tcg_out_mov (s, 3, addr_reg); - tcg_out_rld (s, RLDICL, 4, data_reg, 0, 64 - (1 << (3 + opc))); - tcg_out_movi (s, TCG_TYPE_I64, 5, mem_index); - - tcg_out_call (s, (tcg_target_long) qemu_st_helpers[opc], 1); - - label2_ptr = s->code_ptr; - tcg_out32 (s, B); - - /* label1: fast path */ -#ifdef FAST_PATH - reloc_pc14 (label1_ptr, (tcg_target_long) s->code_ptr); -#endif - - tcg_out32 (s, (LD_ADDEND - | RT (r0) - | RA (r0) - | (offsetof (CPUTLBEntry, addend) - - offsetof (CPUTLBEntry, addr_write)) - )); - /* r0 = env->tlb_table[mem_index][index].addend */ - tcg_out32 (s, ADD | RT (r0) | RA (r0) | RB (addr_reg)); - /* r0 = env->tlb_table[mem_index][index].addend + addr */ - -#else /* !CONFIG_SOFTMMU */ -#if TARGET_LONG_BITS == 32 - tcg_out_rld (s, RLDICL, addr_reg, addr_reg, 0, 32); -#endif - r1 = 3; - r0 = addr_reg; - rbase = GUEST_BASE ? TCG_GUEST_BASE_REG : 0; -#endif - -#ifdef TARGET_WORDS_BIGENDIAN - bswap = 0; -#else - bswap = 1; -#endif - switch (opc) { - case 0: - tcg_out32 (s, STBX | SAB (data_reg, rbase, r0)); - break; - case 1: - if (bswap) - tcg_out32 (s, STHBRX | SAB (data_reg, rbase, r0)); - else - tcg_out32 (s, STHX | SAB (data_reg, rbase, r0)); - break; - case 2: - if (bswap) - tcg_out32 (s, STWBRX | SAB (data_reg, rbase, r0)); - else - tcg_out32 (s, STWX | SAB (data_reg, rbase, r0)); - break; - case 3: - if (bswap) { - tcg_out32 (s, STWBRX | SAB (data_reg, rbase, r0)); - tcg_out32 (s, ADDI | RT (r1) | RA (r0) | 4); - tcg_out_rld (s, RLDICL, 0, data_reg, 32, 0); - tcg_out32 (s, STWBRX | SAB (0, rbase, r1)); - } - else tcg_out32 (s, STDX | SAB (data_reg, rbase, r0)); - break; - } - -#ifdef CONFIG_SOFTMMU - reloc_pc24 (label2_ptr, (tcg_target_long) s->code_ptr); -#endif -} - -void tcg_target_qemu_prologue (TCGContext *s) -{ - int i, frame_size; -#ifndef __APPLE__ - uint64_t addr; -#endif - - frame_size = 0 - + 8 /* back chain */ - + 8 /* CR */ - + 8 /* LR */ - + 8 /* compiler doubleword */ - + 8 /* link editor doubleword */ - + 8 /* TOC save area */ - + TCG_STATIC_CALL_ARGS_SIZE - + ARRAY_SIZE (tcg_target_callee_save_regs) * 8 - ; - frame_size = (frame_size + 15) & ~15; - -#ifndef __APPLE__ - /* First emit adhoc function descriptor */ - addr = (uint64_t) s->code_ptr + 24; - tcg_out32 (s, addr >> 32); tcg_out32 (s, addr); /* entry point */ - s->code_ptr += 16; /* skip TOC and environment pointer */ -#endif - - /* Prologue */ - tcg_out32 (s, MFSPR | RT (0) | LR); - tcg_out32 (s, STDU | RS (1) | RA (1) | (-frame_size & 0xffff)); - for (i = 0; i < ARRAY_SIZE (tcg_target_callee_save_regs); ++i) - tcg_out32 (s, (STD - | RS (tcg_target_callee_save_regs[i]) - | RA (1) - | (i * 8 + 48 + TCG_STATIC_CALL_ARGS_SIZE) - ) - ); - tcg_out32 (s, STD | RS (0) | RA (1) | (frame_size + 16)); - -#ifdef CONFIG_USE_GUEST_BASE - tcg_out_movi (s, TCG_TYPE_I64, TCG_GUEST_BASE_REG, GUEST_BASE); -#endif - - tcg_out32 (s, MTSPR | RS (3) | CTR); - tcg_out32 (s, BCCTR | BO_ALWAYS); - - /* Epilogue */ - tb_ret_addr = s->code_ptr; - - for (i = 0; i < ARRAY_SIZE (tcg_target_callee_save_regs); ++i) - tcg_out32 (s, (LD - | RT (tcg_target_callee_save_regs[i]) - | RA (1) - | (i * 8 + 48 + TCG_STATIC_CALL_ARGS_SIZE) - ) - ); - tcg_out32 (s, LD | RT (0) | RA (1) | (frame_size + 16)); - tcg_out32 (s, MTSPR | RS (0) | LR); - tcg_out32 (s, ADDI | RT (1) | RA (1) | frame_size); - tcg_out32 (s, BCLR | BO_ALWAYS); -} - -static void tcg_out_ld (TCGContext *s, TCGType type, int ret, int arg1, - tcg_target_long arg2) -{ - if (type == TCG_TYPE_I32) - tcg_out_ldst (s, ret, arg1, arg2, LWZ, LWZX); - else - tcg_out_ldsta (s, ret, arg1, arg2, LD, LDX); -} - -static void tcg_out_st (TCGContext *s, TCGType type, int arg, int arg1, - tcg_target_long arg2) -{ - if (type == TCG_TYPE_I32) - tcg_out_ldst (s, arg, arg1, arg2, STW, STWX); - else - tcg_out_ldsta (s, arg, arg1, arg2, STD, STDX); -} - -static void ppc_addi32 (TCGContext *s, int rt, int ra, tcg_target_long si) -{ - if (!si && rt == ra) - return; - - if (si == (int16_t) si) - tcg_out32 (s, ADDI | RT (rt) | RA (ra) | (si & 0xffff)); - else { - uint16_t h = ((si >> 16) & 0xffff) + ((uint16_t) si >> 15); - tcg_out32 (s, ADDIS | RT (rt) | RA (ra) | h); - tcg_out32 (s, ADDI | RT (rt) | RA (rt) | (si & 0xffff)); - } -} - -static void ppc_addi64 (TCGContext *s, int rt, int ra, tcg_target_long si) -{ - /* XXX: suboptimal */ - if (si == (int16_t) si - || ((((uint64_t) si >> 31) == 0) && (si & 0x8000) == 0)) - ppc_addi32 (s, rt, ra, si); - else { - tcg_out_movi (s, TCG_TYPE_I64, 0, si); - tcg_out32 (s, ADD | RT (rt) | RA (ra)); - } -} - -static void tcg_out_addi (TCGContext *s, int reg, tcg_target_long val) -{ - ppc_addi64 (s, reg, reg, val); -} - -static void tcg_out_cmp (TCGContext *s, int cond, TCGArg arg1, TCGArg arg2, - int const_arg2, int cr, int arch64) -{ - int imm; - uint32_t op; - - switch (cond) { - case TCG_COND_EQ: - case TCG_COND_NE: - if (const_arg2) { - if ((int16_t) arg2 == arg2) { - op = CMPI; - imm = 1; - break; - } - else if ((uint16_t) arg2 == arg2) { - op = CMPLI; - imm = 1; - break; - } - } - op = CMPL; - imm = 0; - break; - - case TCG_COND_LT: - case TCG_COND_GE: - case TCG_COND_LE: - case TCG_COND_GT: - if (const_arg2) { - if ((int16_t) arg2 == arg2) { - op = CMPI; - imm = 1; - break; - } - } - op = CMP; - imm = 0; - break; - - case TCG_COND_LTU: - case TCG_COND_GEU: - case TCG_COND_LEU: - case TCG_COND_GTU: - if (const_arg2) { - if ((uint16_t) arg2 == arg2) { - op = CMPLI; - imm = 1; - break; - } - } - op = CMPL; - imm = 0; - break; - - default: - tcg_abort (); - } - op |= BF (cr) | (arch64 << 21); - - if (imm) - tcg_out32 (s, op | RA (arg1) | (arg2 & 0xffff)); - else { - if (const_arg2) { - tcg_out_movi (s, TCG_TYPE_I64, 0, arg2); - tcg_out32 (s, op | RA (arg1) | RB (0)); - } - else - tcg_out32 (s, op | RA (arg1) | RB (arg2)); - } - -} - -static void tcg_out_bc (TCGContext *s, int bc, int label_index) -{ - TCGLabel *l = &s->labels[label_index]; - - if (l->has_value) - tcg_out32 (s, bc | reloc_pc14_val (s->code_ptr, l->u.value)); - else { - uint16_t val = *(uint16_t *) &s->code_ptr[2]; - - /* Thanks to Andrzej Zaborowski */ - tcg_out32 (s, bc | (val & 0xfffc)); - tcg_out_reloc (s, s->code_ptr - 4, R_PPC_REL14, label_index, 0); - } -} - -static void tcg_out_brcond (TCGContext *s, int cond, - TCGArg arg1, TCGArg arg2, int const_arg2, - int label_index, int arch64) -{ - tcg_out_cmp (s, cond, arg1, arg2, const_arg2, 7, arch64); - tcg_out_bc (s, tcg_to_bc[cond], label_index); -} - -void ppc_tb_set_jmp_target (unsigned long jmp_addr, unsigned long addr) -{ - TCGContext s; - unsigned long patch_size; - - s.code_ptr = (uint8_t *) jmp_addr; - tcg_out_b (&s, 0, addr); - patch_size = s.code_ptr - (uint8_t *) jmp_addr; - flush_icache_range (jmp_addr, jmp_addr + patch_size); -} - -static void tcg_out_op (TCGContext *s, int opc, const TCGArg *args, - const int *const_args) -{ - int c; - - switch (opc) { - case INDEX_op_exit_tb: - tcg_out_movi (s, TCG_TYPE_I64, TCG_REG_R3, args[0]); - tcg_out_b (s, 0, (tcg_target_long) tb_ret_addr); - break; - case INDEX_op_goto_tb: - if (s->tb_jmp_offset) { - /* direct jump method */ - - s->tb_jmp_offset[args[0]] = s->code_ptr - s->code_buf; - s->code_ptr += 28; - } - else { - tcg_abort (); - } - s->tb_next_offset[args[0]] = s->code_ptr - s->code_buf; - break; - case INDEX_op_br: - { - TCGLabel *l = &s->labels[args[0]]; - - if (l->has_value) { - tcg_out_b (s, 0, l->u.value); - } - else { - uint32_t val = *(uint32_t *) s->code_ptr; - - /* Thanks to Andrzej Zaborowski */ - tcg_out32 (s, B | (val & 0x3fffffc)); - tcg_out_reloc (s, s->code_ptr - 4, R_PPC_REL24, args[0], 0); - } - } - break; - case INDEX_op_call: - tcg_out_call (s, args[0], const_args[0]); - break; - case INDEX_op_jmp: - if (const_args[0]) { - tcg_out_b (s, 0, args[0]); - } - else { - tcg_out32 (s, MTSPR | RS (args[0]) | CTR); - tcg_out32 (s, BCCTR | BO_ALWAYS); - } - break; - case INDEX_op_movi_i32: - tcg_out_movi (s, TCG_TYPE_I32, args[0], args[1]); - break; - case INDEX_op_movi_i64: - tcg_out_movi (s, TCG_TYPE_I64, args[0], args[1]); - break; - case INDEX_op_ld8u_i32: - case INDEX_op_ld8u_i64: - tcg_out_ldst (s, args[0], args[1], args[2], LBZ, LBZX); - break; - case INDEX_op_ld8s_i32: - case INDEX_op_ld8s_i64: - tcg_out_ldst (s, args[0], args[1], args[2], LBZ, LBZX); - tcg_out32 (s, EXTSB | RS (args[0]) | RA (args[0])); - break; - case INDEX_op_ld16u_i32: - case INDEX_op_ld16u_i64: - tcg_out_ldst (s, args[0], args[1], args[2], LHZ, LHZX); - break; - case INDEX_op_ld16s_i32: - case INDEX_op_ld16s_i64: - tcg_out_ldst (s, args[0], args[1], args[2], LHA, LHAX); - break; - case INDEX_op_ld_i32: - case INDEX_op_ld32u_i64: - tcg_out_ldst (s, args[0], args[1], args[2], LWZ, LWZX); - break; - case INDEX_op_ld32s_i64: - tcg_out_ldsta (s, args[0], args[1], args[2], LWA, LWAX); - break; - case INDEX_op_ld_i64: - tcg_out_ldsta (s, args[0], args[1], args[2], LD, LDX); - break; - case INDEX_op_st8_i32: - case INDEX_op_st8_i64: - tcg_out_ldst (s, args[0], args[1], args[2], STB, STBX); - break; - case INDEX_op_st16_i32: - case INDEX_op_st16_i64: - tcg_out_ldst (s, args[0], args[1], args[2], STH, STHX); - break; - case INDEX_op_st_i32: - case INDEX_op_st32_i64: - tcg_out_ldst (s, args[0], args[1], args[2], STW, STWX); - break; - case INDEX_op_st_i64: - tcg_out_ldsta (s, args[0], args[1], args[2], STD, STDX); - break; - - case INDEX_op_add_i32: - if (const_args[2]) - ppc_addi32 (s, args[0], args[1], args[2]); - else - tcg_out32 (s, ADD | TAB (args[0], args[1], args[2])); - break; - case INDEX_op_sub_i32: - if (const_args[2]) - ppc_addi32 (s, args[0], args[1], -args[2]); - else - tcg_out32 (s, SUBF | TAB (args[0], args[2], args[1])); - break; - - case INDEX_op_and_i64: - case INDEX_op_and_i32: - if (const_args[2]) { - if ((args[2] & 0xffff) == args[2]) - tcg_out32 (s, ANDI | RS (args[1]) | RA (args[0]) | args[2]); - else if ((args[2] & 0xffff0000) == args[2]) - tcg_out32 (s, ANDIS | RS (args[1]) | RA (args[0]) - | ((args[2] >> 16) & 0xffff)); - else { - tcg_out_movi (s, (opc == INDEX_op_and_i32 - ? TCG_TYPE_I32 - : TCG_TYPE_I64), - 0, args[2]); - tcg_out32 (s, AND | SAB (args[1], args[0], 0)); - } - } - else - tcg_out32 (s, AND | SAB (args[1], args[0], args[2])); - break; - case INDEX_op_or_i64: - case INDEX_op_or_i32: - if (const_args[2]) { - if (args[2] & 0xffff) { - tcg_out32 (s, ORI | RS (args[1]) | RA (args[0]) - | (args[2] & 0xffff)); - if (args[2] >> 16) - tcg_out32 (s, ORIS | RS (args[0]) | RA (args[0]) - | ((args[2] >> 16) & 0xffff)); - } - else { - tcg_out32 (s, ORIS | RS (args[1]) | RA (args[0]) - | ((args[2] >> 16) & 0xffff)); - } - } - else - tcg_out32 (s, OR | SAB (args[1], args[0], args[2])); - break; - case INDEX_op_xor_i64: - case INDEX_op_xor_i32: - if (const_args[2]) { - if ((args[2] & 0xffff) == args[2]) - tcg_out32 (s, XORI | RS (args[1]) | RA (args[0]) - | (args[2] & 0xffff)); - else if ((args[2] & 0xffff0000) == args[2]) - tcg_out32 (s, XORIS | RS (args[1]) | RA (args[0]) - | ((args[2] >> 16) & 0xffff)); - else { - tcg_out_movi (s, (opc == INDEX_op_and_i32 - ? TCG_TYPE_I32 - : TCG_TYPE_I64), - 0, args[2]); - tcg_out32 (s, XOR | SAB (args[1], args[0], 0)); - } - } - else - tcg_out32 (s, XOR | SAB (args[1], args[0], args[2])); - break; - - case INDEX_op_mul_i32: - if (const_args[2]) { - if (args[2] == (int16_t) args[2]) - tcg_out32 (s, MULLI | RT (args[0]) | RA (args[1]) - | (args[2] & 0xffff)); - else { - tcg_out_movi (s, TCG_TYPE_I32, 0, args[2]); - tcg_out32 (s, MULLW | TAB (args[0], args[1], 0)); - } - } - else - tcg_out32 (s, MULLW | TAB (args[0], args[1], args[2])); - break; - - case INDEX_op_div_i32: - tcg_out32 (s, DIVW | TAB (args[0], args[1], args[2])); - break; - - case INDEX_op_divu_i32: - tcg_out32 (s, DIVWU | TAB (args[0], args[1], args[2])); - break; - - case INDEX_op_rem_i32: - tcg_out32 (s, DIVW | TAB (0, args[1], args[2])); - tcg_out32 (s, MULLW | TAB (0, 0, args[2])); - tcg_out32 (s, SUBF | TAB (args[0], 0, args[1])); - break; - - case INDEX_op_remu_i32: - tcg_out32 (s, DIVWU | TAB (0, args[1], args[2])); - tcg_out32 (s, MULLW | TAB (0, 0, args[2])); - tcg_out32 (s, SUBF | TAB (args[0], 0, args[1])); - break; - - case INDEX_op_shl_i32: - if (const_args[2]) { - tcg_out32 (s, (RLWINM - | RA (args[0]) - | RS (args[1]) - | SH (args[2]) - | MB (0) - | ME (31 - args[2]) - ) - ); - } - else - tcg_out32 (s, SLW | SAB (args[1], args[0], args[2])); - break; - case INDEX_op_shr_i32: - if (const_args[2]) { - tcg_out32 (s, (RLWINM - | RA (args[0]) - | RS (args[1]) - | SH (32 - args[2]) - | MB (args[2]) - | ME (31) - ) - ); - } - else - tcg_out32 (s, SRW | SAB (args[1], args[0], args[2])); - break; - case INDEX_op_sar_i32: - if (const_args[2]) - tcg_out32 (s, SRAWI | RS (args[1]) | RA (args[0]) | SH (args[2])); - else - tcg_out32 (s, SRAW | SAB (args[1], args[0], args[2])); - break; - - case INDEX_op_brcond_i32: - tcg_out_brcond (s, args[2], args[0], args[1], const_args[1], args[3], 0); - break; - - case INDEX_op_brcond_i64: - tcg_out_brcond (s, args[2], args[0], args[1], const_args[1], args[3], 1); - break; - - case INDEX_op_neg_i32: - case INDEX_op_neg_i64: - tcg_out32 (s, NEG | RT (args[0]) | RA (args[1])); - break; - - case INDEX_op_add_i64: - if (const_args[2]) - ppc_addi64 (s, args[0], args[1], args[2]); - else - tcg_out32 (s, ADD | TAB (args[0], args[1], args[2])); - break; - case INDEX_op_sub_i64: - if (const_args[2]) - ppc_addi64 (s, args[0], args[1], -args[2]); - else - tcg_out32 (s, SUBF | TAB (args[0], args[2], args[1])); - break; - - case INDEX_op_shl_i64: - if (const_args[2]) - tcg_out_rld (s, RLDICR, args[0], args[1], args[2], 63 - args[2]); - else - tcg_out32 (s, SLD | SAB (args[1], args[0], args[2])); - break; - case INDEX_op_shr_i64: - if (const_args[2]) - tcg_out_rld (s, RLDICL, args[0], args[1], 64 - args[2], args[2]); - else - tcg_out32 (s, SRD | SAB (args[1], args[0], args[2])); - break; - case INDEX_op_sar_i64: - if (const_args[2]) { - int sh = SH (args[2] & 0x1f) | (((args[2] >> 5) & 1) << 1); - tcg_out32 (s, SRADI | RA (args[0]) | RS (args[1]) | sh); - } - else - tcg_out32 (s, SRAD | SAB (args[1], args[0], args[2])); - break; - - case INDEX_op_mul_i64: - tcg_out32 (s, MULLD | TAB (args[0], args[1], args[2])); - break; - case INDEX_op_div_i64: - tcg_out32 (s, DIVD | TAB (args[0], args[1], args[2])); - break; - case INDEX_op_divu_i64: - tcg_out32 (s, DIVDU | TAB (args[0], args[1], args[2])); - break; - case INDEX_op_rem_i64: - tcg_out32 (s, DIVD | TAB (0, args[1], args[2])); - tcg_out32 (s, MULLD | TAB (0, 0, args[2])); - tcg_out32 (s, SUBF | TAB (args[0], 0, args[1])); - break; - case INDEX_op_remu_i64: - tcg_out32 (s, DIVDU | TAB (0, args[1], args[2])); - tcg_out32 (s, MULLD | TAB (0, 0, args[2])); - tcg_out32 (s, SUBF | TAB (args[0], 0, args[1])); - break; - - case INDEX_op_qemu_ld8u: - tcg_out_qemu_ld (s, args, 0); - break; - case INDEX_op_qemu_ld8s: - tcg_out_qemu_ld (s, args, 0 | 4); - break; - case INDEX_op_qemu_ld16u: - tcg_out_qemu_ld (s, args, 1); - break; - case INDEX_op_qemu_ld16s: - tcg_out_qemu_ld (s, args, 1 | 4); - break; - case INDEX_op_qemu_ld32u: - tcg_out_qemu_ld (s, args, 2); - break; - case INDEX_op_qemu_ld32s: - tcg_out_qemu_ld (s, args, 2 | 4); - break; - case INDEX_op_qemu_ld64: - tcg_out_qemu_ld (s, args, 3); - break; - case INDEX_op_qemu_st8: - tcg_out_qemu_st (s, args, 0); - break; - case INDEX_op_qemu_st16: - tcg_out_qemu_st (s, args, 1); - break; - case INDEX_op_qemu_st32: - tcg_out_qemu_st (s, args, 2); - break; - case INDEX_op_qemu_st64: - tcg_out_qemu_st (s, args, 3); - break; - - case INDEX_op_ext8s_i32: - case INDEX_op_ext8s_i64: - c = EXTSB; - goto gen_ext; - case INDEX_op_ext16s_i32: - case INDEX_op_ext16s_i64: - c = EXTSH; - goto gen_ext; - case INDEX_op_ext32s_i64: - c = EXTSW; - goto gen_ext; - gen_ext: - tcg_out32 (s, c | RS (args[1]) | RA (args[0])); - break; - - default: - tcg_dump_ops (s, stderr); - tcg_abort (); - } -} - -static const TCGTargetOpDef ppc_op_defs[] = { - { INDEX_op_exit_tb, { } }, - { INDEX_op_goto_tb, { } }, - { INDEX_op_call, { "ri" } }, - { INDEX_op_jmp, { "ri" } }, - { INDEX_op_br, { } }, - - { INDEX_op_mov_i32, { "r", "r" } }, - { INDEX_op_mov_i64, { "r", "r" } }, - { INDEX_op_movi_i32, { "r" } }, - { INDEX_op_movi_i64, { "r" } }, - - { INDEX_op_ld8u_i32, { "r", "r" } }, - { INDEX_op_ld8s_i32, { "r", "r" } }, - { INDEX_op_ld16u_i32, { "r", "r" } }, - { INDEX_op_ld16s_i32, { "r", "r" } }, - { INDEX_op_ld_i32, { "r", "r" } }, - { INDEX_op_ld_i64, { "r", "r" } }, - { INDEX_op_st8_i32, { "r", "r" } }, - { INDEX_op_st8_i64, { "r", "r" } }, - { INDEX_op_st16_i32, { "r", "r" } }, - { INDEX_op_st16_i64, { "r", "r" } }, - { INDEX_op_st_i32, { "r", "r" } }, - { INDEX_op_st_i64, { "r", "r" } }, - { INDEX_op_st32_i64, { "r", "r" } }, - - { INDEX_op_ld8u_i64, { "r", "r" } }, - { INDEX_op_ld8s_i64, { "r", "r" } }, - { INDEX_op_ld16u_i64, { "r", "r" } }, - { INDEX_op_ld16s_i64, { "r", "r" } }, - { INDEX_op_ld32u_i64, { "r", "r" } }, - { INDEX_op_ld32s_i64, { "r", "r" } }, - { INDEX_op_ld_i64, { "r", "r" } }, - - { INDEX_op_add_i32, { "r", "r", "ri" } }, - { INDEX_op_mul_i32, { "r", "r", "ri" } }, - { INDEX_op_div_i32, { "r", "r", "r" } }, - { INDEX_op_divu_i32, { "r", "r", "r" } }, - { INDEX_op_rem_i32, { "r", "r", "r" } }, - { INDEX_op_remu_i32, { "r", "r", "r" } }, - { INDEX_op_sub_i32, { "r", "r", "ri" } }, - { INDEX_op_and_i32, { "r", "r", "ri" } }, - { INDEX_op_or_i32, { "r", "r", "ri" } }, - { INDEX_op_xor_i32, { "r", "r", "ri" } }, - - { INDEX_op_shl_i32, { "r", "r", "ri" } }, - { INDEX_op_shr_i32, { "r", "r", "ri" } }, - { INDEX_op_sar_i32, { "r", "r", "ri" } }, - - { INDEX_op_brcond_i32, { "r", "ri" } }, - { INDEX_op_brcond_i64, { "r", "ri" } }, - - { INDEX_op_neg_i32, { "r", "r" } }, - - { INDEX_op_add_i64, { "r", "r", "ri" } }, - { INDEX_op_sub_i64, { "r", "r", "ri" } }, - { INDEX_op_and_i64, { "r", "r", "rZ" } }, - { INDEX_op_or_i64, { "r", "r", "rZ" } }, - { INDEX_op_xor_i64, { "r", "r", "rZ" } }, - - { INDEX_op_shl_i64, { "r", "r", "ri" } }, - { INDEX_op_shr_i64, { "r", "r", "ri" } }, - { INDEX_op_sar_i64, { "r", "r", "ri" } }, - - { INDEX_op_mul_i64, { "r", "r", "r" } }, - { INDEX_op_div_i64, { "r", "r", "r" } }, - { INDEX_op_divu_i64, { "r", "r", "r" } }, - { INDEX_op_rem_i64, { "r", "r", "r" } }, - { INDEX_op_remu_i64, { "r", "r", "r" } }, - - { INDEX_op_neg_i64, { "r", "r" } }, - - { INDEX_op_qemu_ld8u, { "r", "L" } }, - { INDEX_op_qemu_ld8s, { "r", "L" } }, - { INDEX_op_qemu_ld16u, { "r", "L" } }, - { INDEX_op_qemu_ld16s, { "r", "L" } }, - { INDEX_op_qemu_ld32u, { "r", "L" } }, - { INDEX_op_qemu_ld32s, { "r", "L" } }, - { INDEX_op_qemu_ld64, { "r", "L" } }, - - { INDEX_op_qemu_st8, { "S", "S" } }, - { INDEX_op_qemu_st16, { "S", "S" } }, - { INDEX_op_qemu_st32, { "S", "S" } }, - { INDEX_op_qemu_st64, { "S", "S" } }, - - { INDEX_op_ext8s_i32, { "r", "r" } }, - { INDEX_op_ext16s_i32, { "r", "r" } }, - { INDEX_op_ext8s_i64, { "r", "r" } }, - { INDEX_op_ext16s_i64, { "r", "r" } }, - { INDEX_op_ext32s_i64, { "r", "r" } }, - - { -1 }, -}; - -void tcg_target_init (TCGContext *s) -{ - tcg_regset_set32 (tcg_target_available_regs[TCG_TYPE_I32], 0, 0xffffffff); - tcg_regset_set32 (tcg_target_available_regs[TCG_TYPE_I64], 0, 0xffffffff); - tcg_regset_set32 (tcg_target_call_clobber_regs, 0, - (1 << TCG_REG_R0) | -#ifdef __APPLE__ - (1 << TCG_REG_R2) | -#endif - (1 << TCG_REG_R3) | - (1 << TCG_REG_R4) | - (1 << TCG_REG_R5) | - (1 << TCG_REG_R6) | - (1 << TCG_REG_R7) | - (1 << TCG_REG_R8) | - (1 << TCG_REG_R9) | - (1 << TCG_REG_R10) | - (1 << TCG_REG_R11) | - (1 << TCG_REG_R12) - ); - - tcg_regset_clear (s->reserved_regs); - tcg_regset_set_reg (s->reserved_regs, TCG_REG_R0); - tcg_regset_set_reg (s->reserved_regs, TCG_REG_R1); -#ifndef __APPLE__ - tcg_regset_set_reg (s->reserved_regs, TCG_REG_R2); -#endif - tcg_regset_set_reg (s->reserved_regs, TCG_REG_R13); - -#ifdef CONFIG_USE_GUEST_BASE - tcg_regset_set_reg(s->reserved_regs, TCG_GUEST_BASE_REG); -#endif - - tcg_add_target_add_op_defs (ppc_op_defs); -} diff --git a/qemu/qemu-git/tcg/ppc64/.svn/text-base/tcg-target.h.svn-base b/qemu/qemu-git/tcg/ppc64/.svn/text-base/tcg-target.h.svn-base deleted file mode 100644 index 94b800f..0000000 --- a/qemu/qemu-git/tcg/ppc64/.svn/text-base/tcg-target.h.svn-base +++ /dev/null @@ -1,85 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2008 Fabrice Bellard - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ -#define TCG_TARGET_PPC64 1 - -#define TCG_TARGET_REG_BITS 64 -#define TCG_TARGET_WORDS_BIGENDIAN -#define TCG_TARGET_NB_REGS 32 - -enum { - TCG_REG_R0 = 0, - TCG_REG_R1, - TCG_REG_R2, - TCG_REG_R3, - TCG_REG_R4, - TCG_REG_R5, - TCG_REG_R6, - TCG_REG_R7, - TCG_REG_R8, - TCG_REG_R9, - TCG_REG_R10, - TCG_REG_R11, - TCG_REG_R12, - TCG_REG_R13, - TCG_REG_R14, - TCG_REG_R15, - TCG_REG_R16, - TCG_REG_R17, - TCG_REG_R18, - TCG_REG_R19, - TCG_REG_R20, - TCG_REG_R21, - TCG_REG_R22, - TCG_REG_R23, - TCG_REG_R24, - TCG_REG_R25, - TCG_REG_R26, - TCG_REG_R27, - TCG_REG_R28, - TCG_REG_R29, - TCG_REG_R30, - TCG_REG_R31 -}; - -/* used for function call generation */ -#define TCG_REG_CALL_STACK TCG_REG_R1 -#define TCG_TARGET_STACK_ALIGN 16 -#define TCG_TARGET_CALL_STACK_OFFSET 48 - -/* optional instructions */ -#define TCG_TARGET_HAS_neg_i32 -#define TCG_TARGET_HAS_div_i32 -#define TCG_TARGET_HAS_neg_i64 -#define TCG_TARGET_HAS_div_i64 -#define TCG_TARGET_HAS_ext8s_i32 -#define TCG_TARGET_HAS_ext16s_i32 -#define TCG_TARGET_HAS_ext8s_i64 -#define TCG_TARGET_HAS_ext16s_i64 -#define TCG_TARGET_HAS_ext32s_i64 - -#define TCG_AREG0 TCG_REG_R27 -#define TCG_AREG1 TCG_REG_R24 -#define TCG_AREG2 TCG_REG_R25 - -#define TCG_TARGET_HAS_GUEST_BASE diff --git a/qemu/qemu-git/tcg/s390/.svn/all-wcprops b/qemu/qemu-git/tcg/s390/.svn/all-wcprops deleted file mode 100644 index 27f6b30..0000000 --- a/qemu/qemu-git/tcg/s390/.svn/all-wcprops +++ /dev/null @@ -1,17 +0,0 @@ -K 25 -svn:wc:ra_dav:version-url -V 48 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/s390 -END -tcg-target.c -K 25 -svn:wc:ra_dav:version-url -V 61 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/s390/tcg-target.c -END -tcg-target.h -K 25 -svn:wc:ra_dav:version-url -V 61 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/s390/tcg-target.h -END diff --git a/qemu/qemu-git/tcg/s390/.svn/entries b/qemu/qemu-git/tcg/s390/.svn/entries deleted file mode 100644 index da0d838..0000000 --- a/qemu/qemu-git/tcg/s390/.svn/entries +++ /dev/null @@ -1,96 +0,0 @@ -10 - -dir -11 -http://svn.code.sf.net/p/x49gp/code/qemu/qemu-git/tcg/s390 -http://svn.code.sf.net/p/x49gp/code - - - -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - -481df3bd-3408-496c-b7de-451e46197bb5 - -tcg-target.c -file - - - - -2013-08-23T00:54:47.000000Z -196d09851dc196bf4e4f77be61076d51 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -2922 - -tcg-target.h -file - - - - -2013-08-23T00:54:47.000000Z -a04f358b2b8f2c157a608cdc450336e6 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -2100 - diff --git a/qemu/qemu-git/tcg/s390/.svn/text-base/tcg-target.c.svn-base b/qemu/qemu-git/tcg/s390/.svn/text-base/tcg-target.c.svn-base deleted file mode 100644 index 356b1a4..0000000 --- a/qemu/qemu-git/tcg/s390/.svn/text-base/tcg-target.c.svn-base +++ /dev/null @@ -1,105 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2009 Ulrich Hecht - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ - -static const int tcg_target_reg_alloc_order[] = { -}; - -static const int tcg_target_call_iarg_regs[] = { -}; - -static const int tcg_target_call_oarg_regs[] = { -}; - -static void patch_reloc(uint8_t *code_ptr, int type, - tcg_target_long value, tcg_target_long addend) -{ - tcg_abort(); -} - -static inline int tcg_target_get_call_iarg_regs_count(int flags) -{ - tcg_abort(); - return 0; -} - -/* parse target specific constraints */ -static int target_parse_constraint(TCGArgConstraint *ct, const char **pct_str) -{ - tcg_abort(); - return 0; -} - -/* Test if a constant matches the constraint. */ -static inline int tcg_target_const_match(tcg_target_long val, - const TCGArgConstraint *arg_ct) -{ - tcg_abort(); - return 0; -} - -/* load a register with an immediate value */ -static inline void tcg_out_movi(TCGContext *s, TCGType type, - int ret, tcg_target_long arg) -{ - tcg_abort(); -} - -/* load data without address translation or endianness conversion */ -static inline void tcg_out_ld(TCGContext *s, TCGType type, int arg, - int arg1, tcg_target_long arg2) -{ - tcg_abort(); -} - -static inline void tcg_out_st(TCGContext *s, TCGType type, int arg, - int arg1, tcg_target_long arg2) -{ - tcg_abort(); -} - -static inline void tcg_out_op(TCGContext *s, int opc, - const TCGArg *args, const int *const_args) -{ - tcg_abort(); -} - -void tcg_target_init(TCGContext *s) -{ - /* gets called with KVM */ -} - -void tcg_target_qemu_prologue(TCGContext *s) -{ - /* gets called with KVM */ -} - -static inline void tcg_out_mov(TCGContext *s, int ret, int arg) -{ - tcg_abort(); -} - -static inline void tcg_out_addi(TCGContext *s, int reg, tcg_target_long val) -{ - tcg_abort(); -} diff --git a/qemu/qemu-git/tcg/s390/.svn/text-base/tcg-target.h.svn-base b/qemu/qemu-git/tcg/s390/.svn/text-base/tcg-target.h.svn-base deleted file mode 100644 index 91b931d..0000000 --- a/qemu/qemu-git/tcg/s390/.svn/text-base/tcg-target.h.svn-base +++ /dev/null @@ -1,69 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2009 Ulrich Hecht - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ -#define TCG_TARGET_S390 1 - -#define TCG_TARGET_REG_BITS 64 -#define TCG_TARGET_WORDS_BIGENDIAN - -enum { - TCG_REG_R0 = 0, - TCG_REG_R1, - TCG_REG_R2, - TCG_REG_R3, - TCG_REG_R4, - TCG_REG_R5, - TCG_REG_R6, - TCG_REG_R7, - TCG_REG_R8, - TCG_REG_R9, - TCG_REG_R10, - TCG_REG_R11, - TCG_REG_R12, - TCG_REG_R13, - TCG_REG_R14, - TCG_REG_R15 -}; -#define TCG_TARGET_NB_REGS 16 - -/* used for function call generation */ -#define TCG_REG_CALL_STACK TCG_REG_R15 -#define TCG_TARGET_STACK_ALIGN 8 -#define TCG_TARGET_CALL_STACK_OFFSET 0 - -enum { - /* Note: must be synced with dyngen-exec.h */ - TCG_AREG0 = TCG_REG_R10, - TCG_AREG1 = TCG_REG_R7, - TCG_AREG2 = TCG_REG_R8, - TCG_AREG3 = TCG_REG_R9, -}; - -static inline void flush_icache_range(unsigned long start, unsigned long stop) -{ -#if QEMU_GNUC_PREREQ(4, 1) - __builtin___clear_cache((char *) start, (char *) stop); -#else -#error not implemented -#endif -} diff --git a/qemu/qemu-git/tcg/sparc/.svn/all-wcprops b/qemu/qemu-git/tcg/sparc/.svn/all-wcprops deleted file mode 100644 index 6137292..0000000 --- a/qemu/qemu-git/tcg/sparc/.svn/all-wcprops +++ /dev/null @@ -1,17 +0,0 @@ -K 25 -svn:wc:ra_dav:version-url -V 49 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/sparc -END -tcg-target.c -K 25 -svn:wc:ra_dav:version-url -V 62 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/sparc/tcg-target.c -END -tcg-target.h -K 25 -svn:wc:ra_dav:version-url -V 62 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/sparc/tcg-target.h -END diff --git a/qemu/qemu-git/tcg/sparc/.svn/entries b/qemu/qemu-git/tcg/sparc/.svn/entries deleted file mode 100644 index 85306ba..0000000 --- a/qemu/qemu-git/tcg/sparc/.svn/entries +++ /dev/null @@ -1,96 +0,0 @@ -10 - -dir -11 -http://svn.code.sf.net/p/x49gp/code/qemu/qemu-git/tcg/sparc -http://svn.code.sf.net/p/x49gp/code - - - -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - -481df3bd-3408-496c-b7de-451e46197bb5 - -tcg-target.c -file - - - - -2013-08-23T00:54:47.000000Z -cc77a7d54b957ded0a3786999f2e9927 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -44214 - -tcg-target.h -file - - - - -2013-08-23T00:54:47.000000Z -a9dea207a3126127d800fcb06a8ac4db -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -3583 - diff --git a/qemu/qemu-git/tcg/sparc/.svn/text-base/tcg-target.c.svn-base b/qemu/qemu-git/tcg/sparc/.svn/text-base/tcg-target.c.svn-base deleted file mode 100644 index dd7a598..0000000 --- a/qemu/qemu-git/tcg/sparc/.svn/text-base/tcg-target.c.svn-base +++ /dev/null @@ -1,1402 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2008 Fabrice Bellard - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ - -#ifndef NDEBUG -static const char * const tcg_target_reg_names[TCG_TARGET_NB_REGS] = { - "%g0", - "%g1", - "%g2", - "%g3", - "%g4", - "%g5", - "%g6", - "%g7", - "%o0", - "%o1", - "%o2", - "%o3", - "%o4", - "%o5", - "%o6", - "%o7", - "%l0", - "%l1", - "%l2", - "%l3", - "%l4", - "%l5", - "%l6", - "%l7", - "%i0", - "%i1", - "%i2", - "%i3", - "%i4", - "%i5", - "%i6", - "%i7", -}; -#endif - -static const int tcg_target_reg_alloc_order[] = { - TCG_REG_L0, - TCG_REG_L1, - TCG_REG_L2, - TCG_REG_L3, - TCG_REG_L4, - TCG_REG_L5, - TCG_REG_L6, - TCG_REG_L7, - TCG_REG_I0, - TCG_REG_I1, - TCG_REG_I2, - TCG_REG_I3, - TCG_REG_I4, -}; - -static const int tcg_target_call_iarg_regs[6] = { - TCG_REG_O0, - TCG_REG_O1, - TCG_REG_O2, - TCG_REG_O3, - TCG_REG_O4, - TCG_REG_O5, -}; - -static const int tcg_target_call_oarg_regs[2] = { - TCG_REG_O0, - TCG_REG_O1, -}; - -static inline int check_fit_tl(tcg_target_long val, unsigned int bits) -{ - return (val << ((sizeof(tcg_target_long) * 8 - bits)) - >> (sizeof(tcg_target_long) * 8 - bits)) == val; -} - -static inline int check_fit_i32(uint32_t val, unsigned int bits) -{ - return ((val << (32 - bits)) >> (32 - bits)) == val; -} - -static void patch_reloc(uint8_t *code_ptr, int type, - tcg_target_long value, tcg_target_long addend) -{ - value += addend; - switch (type) { - case R_SPARC_32: - if (value != (uint32_t)value) - tcg_abort(); - *(uint32_t *)code_ptr = value; - break; - case R_SPARC_WDISP22: - value -= (long)code_ptr; - value >>= 2; - if (!check_fit_tl(value, 22)) - tcg_abort(); - *(uint32_t *)code_ptr = ((*(uint32_t *)code_ptr) & ~0x3fffff) | value; - break; - case R_SPARC_WDISP19: - value -= (long)code_ptr; - value >>= 2; - if (!check_fit_tl(value, 19)) - tcg_abort(); - *(uint32_t *)code_ptr = ((*(uint32_t *)code_ptr) & ~0x7ffff) | value; - break; - default: - tcg_abort(); - } -} - -/* maximum number of register used for input function arguments */ -static inline int tcg_target_get_call_iarg_regs_count(int flags) -{ - return 6; -} - -/* parse target specific constraints */ -static int target_parse_constraint(TCGArgConstraint *ct, const char **pct_str) -{ - const char *ct_str; - - ct_str = *pct_str; - switch (ct_str[0]) { - case 'r': - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, 0xffffffff); - break; - case 'L': /* qemu_ld/st constraint */ - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, 0xffffffff); - // Helper args - tcg_regset_reset_reg(ct->u.regs, TCG_REG_O0); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_O1); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_O2); - break; - case 'I': - ct->ct |= TCG_CT_CONST_S11; - break; - case 'J': - ct->ct |= TCG_CT_CONST_S13; - break; - default: - return -1; - } - ct_str++; - *pct_str = ct_str; - return 0; -} - -/* test if a constant matches the constraint */ -static inline int tcg_target_const_match(tcg_target_long val, - const TCGArgConstraint *arg_ct) -{ - int ct; - - ct = arg_ct->ct; - if (ct & TCG_CT_CONST) - return 1; - else if ((ct & TCG_CT_CONST_S11) && check_fit_tl(val, 11)) - return 1; - else if ((ct & TCG_CT_CONST_S13) && check_fit_tl(val, 13)) - return 1; - else - return 0; -} - -#define INSN_OP(x) ((x) << 30) -#define INSN_OP2(x) ((x) << 22) -#define INSN_OP3(x) ((x) << 19) -#define INSN_OPF(x) ((x) << 5) -#define INSN_RD(x) ((x) << 25) -#define INSN_RS1(x) ((x) << 14) -#define INSN_RS2(x) (x) -#define INSN_ASI(x) ((x) << 5) - -#define INSN_IMM13(x) ((1 << 13) | ((x) & 0x1fff)) -#define INSN_OFF19(x) (((x) >> 2) & 0x07ffff) -#define INSN_OFF22(x) (((x) >> 2) & 0x3fffff) - -#define INSN_COND(x, a) (((x) << 25) | ((a) << 29)) -#define COND_N 0x0 -#define COND_E 0x1 -#define COND_LE 0x2 -#define COND_L 0x3 -#define COND_LEU 0x4 -#define COND_CS 0x5 -#define COND_NEG 0x6 -#define COND_VS 0x7 -#define COND_A 0x8 -#define COND_NE 0x9 -#define COND_G 0xa -#define COND_GE 0xb -#define COND_GU 0xc -#define COND_CC 0xd -#define COND_POS 0xe -#define COND_VC 0xf -#define BA (INSN_OP(0) | INSN_COND(COND_A, 0) | INSN_OP2(0x2)) - -#define ARITH_ADD (INSN_OP(2) | INSN_OP3(0x00)) -#define ARITH_ADDCC (INSN_OP(2) | INSN_OP3(0x10)) -#define ARITH_AND (INSN_OP(2) | INSN_OP3(0x01)) -#define ARITH_OR (INSN_OP(2) | INSN_OP3(0x02)) -#define ARITH_ORCC (INSN_OP(2) | INSN_OP3(0x12)) -#define ARITH_XOR (INSN_OP(2) | INSN_OP3(0x03)) -#define ARITH_SUB (INSN_OP(2) | INSN_OP3(0x04)) -#define ARITH_SUBCC (INSN_OP(2) | INSN_OP3(0x14)) -#define ARITH_ADDX (INSN_OP(2) | INSN_OP3(0x10)) -#define ARITH_SUBX (INSN_OP(2) | INSN_OP3(0x0c)) -#define ARITH_UMUL (INSN_OP(2) | INSN_OP3(0x0a)) -#define ARITH_UDIV (INSN_OP(2) | INSN_OP3(0x0e)) -#define ARITH_SDIV (INSN_OP(2) | INSN_OP3(0x0f)) -#define ARITH_MULX (INSN_OP(2) | INSN_OP3(0x09)) -#define ARITH_UDIVX (INSN_OP(2) | INSN_OP3(0x0d)) -#define ARITH_SDIVX (INSN_OP(2) | INSN_OP3(0x2d)) - -#define SHIFT_SLL (INSN_OP(2) | INSN_OP3(0x25)) -#define SHIFT_SRL (INSN_OP(2) | INSN_OP3(0x26)) -#define SHIFT_SRA (INSN_OP(2) | INSN_OP3(0x27)) - -#define SHIFT_SLLX (INSN_OP(2) | INSN_OP3(0x25) | (1 << 12)) -#define SHIFT_SRLX (INSN_OP(2) | INSN_OP3(0x26) | (1 << 12)) -#define SHIFT_SRAX (INSN_OP(2) | INSN_OP3(0x27) | (1 << 12)) - -#define RDY (INSN_OP(2) | INSN_OP3(0x28) | INSN_RS1(0)) -#define WRY (INSN_OP(2) | INSN_OP3(0x30) | INSN_RD(0)) -#define JMPL (INSN_OP(2) | INSN_OP3(0x38)) -#define SAVE (INSN_OP(2) | INSN_OP3(0x3c)) -#define RESTORE (INSN_OP(2) | INSN_OP3(0x3d)) -#define SETHI (INSN_OP(0) | INSN_OP2(0x4)) -#define CALL INSN_OP(1) -#define LDUB (INSN_OP(3) | INSN_OP3(0x01)) -#define LDSB (INSN_OP(3) | INSN_OP3(0x09)) -#define LDUH (INSN_OP(3) | INSN_OP3(0x02)) -#define LDSH (INSN_OP(3) | INSN_OP3(0x0a)) -#define LDUW (INSN_OP(3) | INSN_OP3(0x00)) -#define LDSW (INSN_OP(3) | INSN_OP3(0x08)) -#define LDX (INSN_OP(3) | INSN_OP3(0x0b)) -#define STB (INSN_OP(3) | INSN_OP3(0x05)) -#define STH (INSN_OP(3) | INSN_OP3(0x06)) -#define STW (INSN_OP(3) | INSN_OP3(0x04)) -#define STX (INSN_OP(3) | INSN_OP3(0x0e)) -#define LDUBA (INSN_OP(3) | INSN_OP3(0x11)) -#define LDSBA (INSN_OP(3) | INSN_OP3(0x19)) -#define LDUHA (INSN_OP(3) | INSN_OP3(0x12)) -#define LDSHA (INSN_OP(3) | INSN_OP3(0x1a)) -#define LDUWA (INSN_OP(3) | INSN_OP3(0x10)) -#define LDSWA (INSN_OP(3) | INSN_OP3(0x18)) -#define LDXA (INSN_OP(3) | INSN_OP3(0x1b)) -#define STBA (INSN_OP(3) | INSN_OP3(0x15)) -#define STHA (INSN_OP(3) | INSN_OP3(0x16)) -#define STWA (INSN_OP(3) | INSN_OP3(0x14)) -#define STXA (INSN_OP(3) | INSN_OP3(0x1e)) - -#ifndef ASI_PRIMARY_LITTLE -#define ASI_PRIMARY_LITTLE 0x88 -#endif - -static inline void tcg_out_arith(TCGContext *s, int rd, int rs1, int rs2, - int op) -{ - tcg_out32(s, op | INSN_RD(rd) | INSN_RS1(rs1) | - INSN_RS2(rs2)); -} - -static inline void tcg_out_arithi(TCGContext *s, int rd, int rs1, - uint32_t offset, int op) -{ - tcg_out32(s, op | INSN_RD(rd) | INSN_RS1(rs1) | - INSN_IMM13(offset)); -} - -static void tcg_out_arithc(TCGContext *s, int rd, int rs1, - int val2, int val2const, int op) -{ - tcg_out32(s, op | INSN_RD(rd) | INSN_RS1(rs1) - | (val2const ? INSN_IMM13(val2) : INSN_RS2(val2))); -} - -static inline void tcg_out_mov(TCGContext *s, int ret, int arg) -{ - tcg_out_arith(s, ret, arg, TCG_REG_G0, ARITH_OR); -} - -static inline void tcg_out_sethi(TCGContext *s, int ret, uint32_t arg) -{ - tcg_out32(s, SETHI | INSN_RD(ret) | ((arg & 0xfffffc00) >> 10)); -} - -static inline void tcg_out_movi_imm13(TCGContext *s, int ret, uint32_t arg) -{ - tcg_out_arithi(s, ret, TCG_REG_G0, arg, ARITH_OR); -} - -static inline void tcg_out_movi_imm32(TCGContext *s, int ret, uint32_t arg) -{ - if (check_fit_tl(arg, 13)) - tcg_out_movi_imm13(s, ret, arg); - else { - tcg_out_sethi(s, ret, arg); - if (arg & 0x3ff) - tcg_out_arithi(s, ret, ret, arg & 0x3ff, ARITH_OR); - } -} - -static inline void tcg_out_movi(TCGContext *s, TCGType type, - int ret, tcg_target_long arg) -{ - /* All 32-bit constants, as well as 64-bit constants with - no high bits set go through movi_imm32. */ - if (TCG_TARGET_REG_BITS == 32 - || type == TCG_TYPE_I32 - || (arg & ~(tcg_target_long)0xffffffff) == 0) { - tcg_out_movi_imm32(s, ret, arg); - } else if (check_fit_tl(arg, 13)) { - /* A 13-bit constant sign-extended to 64-bits. */ - tcg_out_movi_imm13(s, ret, arg); - } else if (check_fit_tl(arg, 32)) { - /* A 32-bit constant sign-extended to 64-bits. */ - tcg_out_sethi(s, ret, ~arg); - tcg_out_arithi(s, ret, ret, (arg & 0x3ff) | -0x400, ARITH_XOR); - } else { - tcg_out_movi_imm32(s, TCG_REG_I4, arg >> (TCG_TARGET_REG_BITS / 2)); - tcg_out_arithi(s, TCG_REG_I4, TCG_REG_I4, 32, SHIFT_SLLX); - tcg_out_movi_imm32(s, ret, arg); - tcg_out_arith(s, ret, ret, TCG_REG_I4, ARITH_OR); - } -} - -static inline void tcg_out_ld_raw(TCGContext *s, int ret, - tcg_target_long arg) -{ - tcg_out_sethi(s, ret, arg); - tcg_out32(s, LDUW | INSN_RD(ret) | INSN_RS1(ret) | - INSN_IMM13(arg & 0x3ff)); -} - -static inline void tcg_out_ld_ptr(TCGContext *s, int ret, - tcg_target_long arg) -{ - if (!check_fit_tl(arg, 10)) - tcg_out_movi(s, TCG_TYPE_PTR, ret, arg & ~0x3ffULL); - if (TCG_TARGET_REG_BITS == 64) { - tcg_out32(s, LDX | INSN_RD(ret) | INSN_RS1(ret) | - INSN_IMM13(arg & 0x3ff)); - } else { - tcg_out32(s, LDUW | INSN_RD(ret) | INSN_RS1(ret) | - INSN_IMM13(arg & 0x3ff)); - } -} - -static inline void tcg_out_ldst(TCGContext *s, int ret, int addr, int offset, int op) -{ - if (check_fit_tl(offset, 13)) - tcg_out32(s, op | INSN_RD(ret) | INSN_RS1(addr) | - INSN_IMM13(offset)); - else { - tcg_out_movi(s, TCG_TYPE_PTR, TCG_REG_I5, offset); - tcg_out32(s, op | INSN_RD(ret) | INSN_RS1(TCG_REG_I5) | - INSN_RS2(addr)); - } -} - -static inline void tcg_out_ldst_asi(TCGContext *s, int ret, int addr, - int offset, int op, int asi) -{ - tcg_out_movi(s, TCG_TYPE_PTR, TCG_REG_I5, offset); - tcg_out32(s, op | INSN_RD(ret) | INSN_RS1(TCG_REG_I5) | - INSN_ASI(asi) | INSN_RS2(addr)); -} - -static inline void tcg_out_ld(TCGContext *s, TCGType type, int ret, - int arg1, tcg_target_long arg2) -{ - if (type == TCG_TYPE_I32) - tcg_out_ldst(s, ret, arg1, arg2, LDUW); - else - tcg_out_ldst(s, ret, arg1, arg2, LDX); -} - -static inline void tcg_out_st(TCGContext *s, TCGType type, int arg, - int arg1, tcg_target_long arg2) -{ - if (type == TCG_TYPE_I32) - tcg_out_ldst(s, arg, arg1, arg2, STW); - else - tcg_out_ldst(s, arg, arg1, arg2, STX); -} - -static inline void tcg_out_sety(TCGContext *s, int rs) -{ - tcg_out32(s, WRY | INSN_RS1(TCG_REG_G0) | INSN_RS2(rs)); -} - -static inline void tcg_out_rdy(TCGContext *s, int rd) -{ - tcg_out32(s, RDY | INSN_RD(rd)); -} - -static inline void tcg_out_addi(TCGContext *s, int reg, tcg_target_long val) -{ - if (val != 0) { - if (check_fit_tl(val, 13)) - tcg_out_arithi(s, reg, reg, val, ARITH_ADD); - else { - tcg_out_movi(s, TCG_TYPE_PTR, TCG_REG_I5, val); - tcg_out_arith(s, reg, reg, TCG_REG_I5, ARITH_ADD); - } - } -} - -static inline void tcg_out_andi(TCGContext *s, int reg, tcg_target_long val) -{ - if (val != 0) { - if (check_fit_tl(val, 13)) - tcg_out_arithi(s, reg, reg, val, ARITH_AND); - else { - tcg_out_movi(s, TCG_TYPE_I32, TCG_REG_I5, val); - tcg_out_arith(s, reg, reg, TCG_REG_I5, ARITH_AND); - } - } -} - -static void tcg_out_div32(TCGContext *s, int rd, int rs1, - int val2, int val2const, int uns) -{ - /* Load Y with the sign/zero extension of RS1 to 64-bits. */ - if (uns) { - tcg_out_sety(s, TCG_REG_G0); - } else { - tcg_out_arithi(s, TCG_REG_I5, rs1, 31, SHIFT_SRA); - tcg_out_sety(s, TCG_REG_I5); - } - - tcg_out_arithc(s, rd, rs1, val2, val2const, - uns ? ARITH_UDIV : ARITH_SDIV); -} - -static inline void tcg_out_nop(TCGContext *s) -{ - tcg_out_sethi(s, TCG_REG_G0, 0); -} - -static void tcg_out_branch_i32(TCGContext *s, int opc, int label_index) -{ - int32_t val; - TCGLabel *l = &s->labels[label_index]; - - if (l->has_value) { - val = l->u.value - (tcg_target_long)s->code_ptr; - tcg_out32(s, (INSN_OP(0) | INSN_COND(opc, 0) | INSN_OP2(0x2) - | INSN_OFF22(l->u.value - (unsigned long)s->code_ptr))); - } else { - tcg_out_reloc(s, s->code_ptr, R_SPARC_WDISP22, label_index, 0); - tcg_out32(s, (INSN_OP(0) | INSN_COND(opc, 0) | INSN_OP2(0x2) | 0)); - } -} - -#if TCG_TARGET_REG_BITS == 64 -static void tcg_out_branch_i64(TCGContext *s, int opc, int label_index) -{ - int32_t val; - TCGLabel *l = &s->labels[label_index]; - - if (l->has_value) { - val = l->u.value - (tcg_target_long)s->code_ptr; - tcg_out32(s, (INSN_OP(0) | INSN_COND(opc, 0) | INSN_OP2(0x1) | - (0x5 << 19) | - INSN_OFF19(l->u.value - (unsigned long)s->code_ptr))); - } else { - tcg_out_reloc(s, s->code_ptr, R_SPARC_WDISP19, label_index, 0); - tcg_out32(s, (INSN_OP(0) | INSN_COND(opc, 0) | INSN_OP2(0x1) | - (0x5 << 19) | 0)); - } -} -#endif - -static const uint8_t tcg_cond_to_bcond[10] = { - [TCG_COND_EQ] = COND_E, - [TCG_COND_NE] = COND_NE, - [TCG_COND_LT] = COND_L, - [TCG_COND_GE] = COND_GE, - [TCG_COND_LE] = COND_LE, - [TCG_COND_GT] = COND_G, - [TCG_COND_LTU] = COND_CS, - [TCG_COND_GEU] = COND_CC, - [TCG_COND_LEU] = COND_LEU, - [TCG_COND_GTU] = COND_GU, -}; - -static void tcg_out_cmp(TCGContext *s, TCGArg c1, TCGArg c2, int c2const) -{ - tcg_out_arithc(s, TCG_REG_G0, c1, c2, c2const, ARITH_SUBCC); -} - -static void tcg_out_brcond_i32(TCGContext *s, int cond, - TCGArg arg1, TCGArg arg2, int const_arg2, - int label_index) -{ - tcg_out_cmp(s, arg1, arg2, const_arg2); - tcg_out_branch_i32(s, tcg_cond_to_bcond[cond], label_index); - tcg_out_nop(s); -} - -#if TCG_TARGET_REG_BITS == 64 -static void tcg_out_brcond_i64(TCGContext *s, int cond, - TCGArg arg1, TCGArg arg2, int const_arg2, - int label_index) -{ - tcg_out_cmp(s, arg1, arg2, const_arg2); - tcg_out_branch_i64(s, tcg_cond_to_bcond[cond], label_index); - tcg_out_nop(s); -} -#else -static void tcg_out_brcond2_i32(TCGContext *s, int cond, - TCGArg al, TCGArg ah, - TCGArg bl, int blconst, - TCGArg bh, int bhconst, int label_dest) -{ - int cc, label_next = gen_new_label(); - - tcg_out_cmp(s, ah, bh, bhconst); - - /* Note that we fill one of the delay slots with the second compare. */ - switch (cond) { - case TCG_COND_EQ: - cc = INSN_COND(tcg_cond_to_bcond[TCG_COND_NE], 0); - tcg_out_branch_i32(s, cc, label_next); - tcg_out_cmp(s, al, bl, blconst); - cc = INSN_COND(tcg_cond_to_bcond[TCG_COND_EQ], 0); - tcg_out_branch_i32(s, cc, label_dest); - break; - - case TCG_COND_NE: - cc = INSN_COND(tcg_cond_to_bcond[TCG_COND_NE], 0); - tcg_out_branch_i32(s, cc, label_dest); - tcg_out_cmp(s, al, bl, blconst); - tcg_out_branch_i32(s, cc, label_dest); - break; - - default: - /* ??? One could fairly easily special-case 64-bit unsigned - compares against 32-bit zero-extended constants. For instance, - we know that (unsigned)AH < 0 is false and need not emit it. - Similarly, (unsigned)AH > 0 being true implies AH != 0, so the - second branch will never be taken. */ - cc = INSN_COND(tcg_cond_to_bcond[cond], 0); - tcg_out_branch_i32(s, cc, label_dest); - tcg_out_nop(s); - cc = INSN_COND(tcg_cond_to_bcond[TCG_COND_NE], 0); - tcg_out_branch_i32(s, cc, label_next); - tcg_out_cmp(s, al, bl, blconst); - cc = INSN_COND(tcg_cond_to_bcond[tcg_unsigned_cond(cond)], 0); - tcg_out_branch_i32(s, cc, label_dest); - break; - } - tcg_out_nop(s); - - tcg_out_label(s, label_next, (tcg_target_long)s->code_ptr); -} -#endif - -/* Generate global QEMU prologue and epilogue code */ -void tcg_target_qemu_prologue(TCGContext *s) -{ - tcg_out32(s, SAVE | INSN_RD(TCG_REG_O6) | INSN_RS1(TCG_REG_O6) | - INSN_IMM13(-TCG_TARGET_STACK_MINFRAME)); - tcg_out32(s, JMPL | INSN_RD(TCG_REG_G0) | INSN_RS1(TCG_REG_I0) | - INSN_RS2(TCG_REG_G0)); - tcg_out_nop(s); -} - -#if defined(CONFIG_SOFTMMU) - -#include "../../softmmu_defs.h" - -static const void * const qemu_ld_helpers[4] = { - __ldb_mmu, - __ldw_mmu, - __ldl_mmu, - __ldq_mmu, -}; - -static const void * const qemu_st_helpers[4] = { - __stb_mmu, - __stw_mmu, - __stl_mmu, - __stq_mmu, -}; -#endif - -#if TARGET_LONG_BITS == 32 -#define TARGET_LD_OP LDUW -#else -#define TARGET_LD_OP LDX -#endif - -#if TARGET_PHYS_ADDR_BITS == 32 -#define TARGET_ADDEND_LD_OP LDUW -#else -#define TARGET_ADDEND_LD_OP LDX -#endif - -#ifdef __arch64__ -#define HOST_LD_OP LDX -#define HOST_ST_OP STX -#define HOST_SLL_OP SHIFT_SLLX -#define HOST_SRA_OP SHIFT_SRAX -#else -#define HOST_LD_OP LDUW -#define HOST_ST_OP STW -#define HOST_SLL_OP SHIFT_SLL -#define HOST_SRA_OP SHIFT_SRA -#endif - -static void tcg_out_qemu_ld(TCGContext *s, const TCGArg *args, - int opc) -{ - int addr_reg, data_reg, arg0, arg1, arg2, mem_index, s_bits; -#if defined(CONFIG_SOFTMMU) - uint32_t *label1_ptr, *label2_ptr; -#endif - - data_reg = *args++; - addr_reg = *args++; - mem_index = *args; - s_bits = opc & 3; - - arg0 = TCG_REG_O0; - arg1 = TCG_REG_O1; - arg2 = TCG_REG_O2; - -#if defined(CONFIG_SOFTMMU) - /* srl addr_reg, x, arg1 */ - tcg_out_arithi(s, arg1, addr_reg, TARGET_PAGE_BITS - CPU_TLB_ENTRY_BITS, - SHIFT_SRL); - /* and addr_reg, x, arg0 */ - tcg_out_arithi(s, arg0, addr_reg, TARGET_PAGE_MASK | ((1 << s_bits) - 1), - ARITH_AND); - - /* and arg1, x, arg1 */ - tcg_out_andi(s, arg1, (CPU_TLB_SIZE - 1) << CPU_TLB_ENTRY_BITS); - - /* add arg1, x, arg1 */ - tcg_out_addi(s, arg1, offsetof(CPUState, - tlb_table[mem_index][0].addr_read)); - - /* add env, arg1, arg1 */ - tcg_out_arith(s, arg1, TCG_AREG0, arg1, ARITH_ADD); - - /* ld [arg1], arg2 */ - tcg_out32(s, TARGET_LD_OP | INSN_RD(arg2) | INSN_RS1(arg1) | - INSN_RS2(TCG_REG_G0)); - - /* subcc arg0, arg2, %g0 */ - tcg_out_arith(s, TCG_REG_G0, arg0, arg2, ARITH_SUBCC); - - /* will become: - be label1 - or - be,pt %xcc label1 */ - label1_ptr = (uint32_t *)s->code_ptr; - tcg_out32(s, 0); - - /* mov (delay slot) */ - tcg_out_mov(s, arg0, addr_reg); - - /* mov */ - tcg_out_movi(s, TCG_TYPE_I32, arg1, mem_index); - - /* XXX: move that code at the end of the TB */ - /* qemu_ld_helper[s_bits](arg0, arg1) */ - tcg_out32(s, CALL | ((((tcg_target_ulong)qemu_ld_helpers[s_bits] - - (tcg_target_ulong)s->code_ptr) >> 2) - & 0x3fffffff)); - /* Store AREG0 in stack to avoid ugly glibc bugs that mangle - global registers */ - // delay slot - tcg_out_ldst(s, TCG_AREG0, TCG_REG_CALL_STACK, - TCG_TARGET_CALL_STACK_OFFSET - TCG_STATIC_CALL_ARGS_SIZE - - sizeof(long), HOST_ST_OP); - tcg_out_ldst(s, TCG_AREG0, TCG_REG_CALL_STACK, - TCG_TARGET_CALL_STACK_OFFSET - TCG_STATIC_CALL_ARGS_SIZE - - sizeof(long), HOST_LD_OP); - - /* data_reg = sign_extend(arg0) */ - switch(opc) { - case 0 | 4: - /* sll arg0, 24/56, data_reg */ - tcg_out_arithi(s, data_reg, arg0, (int)sizeof(tcg_target_long) * 8 - 8, - HOST_SLL_OP); - /* sra data_reg, 24/56, data_reg */ - tcg_out_arithi(s, data_reg, data_reg, - (int)sizeof(tcg_target_long) * 8 - 8, HOST_SRA_OP); - break; - case 1 | 4: - /* sll arg0, 16/48, data_reg */ - tcg_out_arithi(s, data_reg, arg0, - (int)sizeof(tcg_target_long) * 8 - 16, HOST_SLL_OP); - /* sra data_reg, 16/48, data_reg */ - tcg_out_arithi(s, data_reg, data_reg, - (int)sizeof(tcg_target_long) * 8 - 16, HOST_SRA_OP); - break; - case 2 | 4: - /* sll arg0, 32, data_reg */ - tcg_out_arithi(s, data_reg, arg0, 32, HOST_SLL_OP); - /* sra data_reg, 32, data_reg */ - tcg_out_arithi(s, data_reg, data_reg, 32, HOST_SRA_OP); - break; - case 0: - case 1: - case 2: - case 3: - default: - /* mov */ - tcg_out_mov(s, data_reg, arg0); - break; - } - - /* will become: - ba label2 */ - label2_ptr = (uint32_t *)s->code_ptr; - tcg_out32(s, 0); - - /* nop (delay slot */ - tcg_out_nop(s); - - /* label1: */ -#if TARGET_LONG_BITS == 32 - /* be label1 */ - *label1_ptr = (INSN_OP(0) | INSN_COND(COND_E, 0) | INSN_OP2(0x2) | - INSN_OFF22((unsigned long)s->code_ptr - - (unsigned long)label1_ptr)); -#else - /* be,pt %xcc label1 */ - *label1_ptr = (INSN_OP(0) | INSN_COND(COND_E, 0) | INSN_OP2(0x1) | - (0x5 << 19) | INSN_OFF19((unsigned long)s->code_ptr - - (unsigned long)label1_ptr)); -#endif - - /* ld [arg1 + x], arg1 */ - tcg_out_ldst(s, arg1, arg1, offsetof(CPUTLBEntry, addend) - - offsetof(CPUTLBEntry, addr_read), TARGET_ADDEND_LD_OP); - -#if TARGET_LONG_BITS == 32 - /* and addr_reg, x, arg0 */ - tcg_out_movi(s, TCG_TYPE_I32, TCG_REG_I5, 0xffffffff); - tcg_out_arith(s, arg0, addr_reg, TCG_REG_I5, ARITH_AND); - /* add arg0, arg1, arg0 */ - tcg_out_arith(s, arg0, arg0, arg1, ARITH_ADD); -#else - /* add addr_reg, arg1, arg0 */ - tcg_out_arith(s, arg0, addr_reg, arg1, ARITH_ADD); -#endif - -#else - arg0 = addr_reg; -#endif - - switch(opc) { - case 0: - /* ldub [arg0], data_reg */ - tcg_out_ldst(s, data_reg, arg0, 0, LDUB); - break; - case 0 | 4: - /* ldsb [arg0], data_reg */ - tcg_out_ldst(s, data_reg, arg0, 0, LDSB); - break; - case 1: -#ifdef TARGET_WORDS_BIGENDIAN - /* lduh [arg0], data_reg */ - tcg_out_ldst(s, data_reg, arg0, 0, LDUH); -#else - /* lduha [arg0] ASI_PRIMARY_LITTLE, data_reg */ - tcg_out_ldst_asi(s, data_reg, arg0, 0, LDUHA, ASI_PRIMARY_LITTLE); -#endif - break; - case 1 | 4: -#ifdef TARGET_WORDS_BIGENDIAN - /* ldsh [arg0], data_reg */ - tcg_out_ldst(s, data_reg, arg0, 0, LDSH); -#else - /* ldsha [arg0] ASI_PRIMARY_LITTLE, data_reg */ - tcg_out_ldst_asi(s, data_reg, arg0, 0, LDSHA, ASI_PRIMARY_LITTLE); -#endif - break; - case 2: -#ifdef TARGET_WORDS_BIGENDIAN - /* lduw [arg0], data_reg */ - tcg_out_ldst(s, data_reg, arg0, 0, LDUW); -#else - /* lduwa [arg0] ASI_PRIMARY_LITTLE, data_reg */ - tcg_out_ldst_asi(s, data_reg, arg0, 0, LDUWA, ASI_PRIMARY_LITTLE); -#endif - break; - case 2 | 4: -#ifdef TARGET_WORDS_BIGENDIAN - /* ldsw [arg0], data_reg */ - tcg_out_ldst(s, data_reg, arg0, 0, LDSW); -#else - /* ldswa [arg0] ASI_PRIMARY_LITTLE, data_reg */ - tcg_out_ldst_asi(s, data_reg, arg0, 0, LDSWA, ASI_PRIMARY_LITTLE); -#endif - break; - case 3: -#ifdef TARGET_WORDS_BIGENDIAN - /* ldx [arg0], data_reg */ - tcg_out_ldst(s, data_reg, arg0, 0, LDX); -#else - /* ldxa [arg0] ASI_PRIMARY_LITTLE, data_reg */ - tcg_out_ldst_asi(s, data_reg, arg0, 0, LDXA, ASI_PRIMARY_LITTLE); -#endif - break; - default: - tcg_abort(); - } - -#if defined(CONFIG_SOFTMMU) - /* label2: */ - *label2_ptr = (INSN_OP(0) | INSN_COND(COND_A, 0) | INSN_OP2(0x2) | - INSN_OFF22((unsigned long)s->code_ptr - - (unsigned long)label2_ptr)); -#endif -} - -static void tcg_out_qemu_st(TCGContext *s, const TCGArg *args, - int opc) -{ - int addr_reg, data_reg, arg0, arg1, arg2, mem_index, s_bits; -#if defined(CONFIG_SOFTMMU) - uint32_t *label1_ptr, *label2_ptr; -#endif - - data_reg = *args++; - addr_reg = *args++; - mem_index = *args; - - s_bits = opc; - - arg0 = TCG_REG_O0; - arg1 = TCG_REG_O1; - arg2 = TCG_REG_O2; - -#if defined(CONFIG_SOFTMMU) - /* srl addr_reg, x, arg1 */ - tcg_out_arithi(s, arg1, addr_reg, TARGET_PAGE_BITS - CPU_TLB_ENTRY_BITS, - SHIFT_SRL); - - /* and addr_reg, x, arg0 */ - tcg_out_arithi(s, arg0, addr_reg, TARGET_PAGE_MASK | ((1 << s_bits) - 1), - ARITH_AND); - - /* and arg1, x, arg1 */ - tcg_out_andi(s, arg1, (CPU_TLB_SIZE - 1) << CPU_TLB_ENTRY_BITS); - - /* add arg1, x, arg1 */ - tcg_out_addi(s, arg1, offsetof(CPUState, - tlb_table[mem_index][0].addr_write)); - - /* add env, arg1, arg1 */ - tcg_out_arith(s, arg1, TCG_AREG0, arg1, ARITH_ADD); - - /* ld [arg1], arg2 */ - tcg_out32(s, TARGET_LD_OP | INSN_RD(arg2) | INSN_RS1(arg1) | - INSN_RS2(TCG_REG_G0)); - - /* subcc arg0, arg2, %g0 */ - tcg_out_arith(s, TCG_REG_G0, arg0, arg2, ARITH_SUBCC); - - /* will become: - be label1 - or - be,pt %xcc label1 */ - label1_ptr = (uint32_t *)s->code_ptr; - tcg_out32(s, 0); - - /* mov (delay slot) */ - tcg_out_mov(s, arg0, addr_reg); - - /* mov */ - tcg_out_mov(s, arg1, data_reg); - - /* mov */ - tcg_out_movi(s, TCG_TYPE_I32, arg2, mem_index); - - /* XXX: move that code at the end of the TB */ - /* qemu_st_helper[s_bits](arg0, arg1, arg2) */ - tcg_out32(s, CALL | ((((tcg_target_ulong)qemu_st_helpers[s_bits] - - (tcg_target_ulong)s->code_ptr) >> 2) - & 0x3fffffff)); - /* Store AREG0 in stack to avoid ugly glibc bugs that mangle - global registers */ - // delay slot - tcg_out_ldst(s, TCG_AREG0, TCG_REG_CALL_STACK, - TCG_TARGET_CALL_STACK_OFFSET - TCG_STATIC_CALL_ARGS_SIZE - - sizeof(long), HOST_ST_OP); - tcg_out_ldst(s, TCG_AREG0, TCG_REG_CALL_STACK, - TCG_TARGET_CALL_STACK_OFFSET - TCG_STATIC_CALL_ARGS_SIZE - - sizeof(long), HOST_LD_OP); - - /* will become: - ba label2 */ - label2_ptr = (uint32_t *)s->code_ptr; - tcg_out32(s, 0); - - /* nop (delay slot) */ - tcg_out_nop(s); - -#if TARGET_LONG_BITS == 32 - /* be label1 */ - *label1_ptr = (INSN_OP(0) | INSN_COND(COND_E, 0) | INSN_OP2(0x2) | - INSN_OFF22((unsigned long)s->code_ptr - - (unsigned long)label1_ptr)); -#else - /* be,pt %xcc label1 */ - *label1_ptr = (INSN_OP(0) | INSN_COND(COND_E, 0) | INSN_OP2(0x1) | - (0x5 << 19) | INSN_OFF19((unsigned long)s->code_ptr - - (unsigned long)label1_ptr)); -#endif - - /* ld [arg1 + x], arg1 */ - tcg_out_ldst(s, arg1, arg1, offsetof(CPUTLBEntry, addend) - - offsetof(CPUTLBEntry, addr_write), TARGET_ADDEND_LD_OP); - -#if TARGET_LONG_BITS == 32 - /* and addr_reg, x, arg0 */ - tcg_out_movi(s, TCG_TYPE_I32, TCG_REG_I5, 0xffffffff); - tcg_out_arith(s, arg0, addr_reg, TCG_REG_I5, ARITH_AND); - /* add arg0, arg1, arg0 */ - tcg_out_arith(s, arg0, arg0, arg1, ARITH_ADD); -#else - /* add addr_reg, arg1, arg0 */ - tcg_out_arith(s, arg0, addr_reg, arg1, ARITH_ADD); -#endif - -#else - arg0 = addr_reg; -#endif - - switch(opc) { - case 0: - /* stb data_reg, [arg0] */ - tcg_out_ldst(s, data_reg, arg0, 0, STB); - break; - case 1: -#ifdef TARGET_WORDS_BIGENDIAN - /* sth data_reg, [arg0] */ - tcg_out_ldst(s, data_reg, arg0, 0, STH); -#else - /* stha data_reg, [arg0] ASI_PRIMARY_LITTLE */ - tcg_out_ldst_asi(s, data_reg, arg0, 0, STHA, ASI_PRIMARY_LITTLE); -#endif - break; - case 2: -#ifdef TARGET_WORDS_BIGENDIAN - /* stw data_reg, [arg0] */ - tcg_out_ldst(s, data_reg, arg0, 0, STW); -#else - /* stwa data_reg, [arg0] ASI_PRIMARY_LITTLE */ - tcg_out_ldst_asi(s, data_reg, arg0, 0, STWA, ASI_PRIMARY_LITTLE); -#endif - break; - case 3: -#ifdef TARGET_WORDS_BIGENDIAN - /* stx data_reg, [arg0] */ - tcg_out_ldst(s, data_reg, arg0, 0, STX); -#else - /* stxa data_reg, [arg0] ASI_PRIMARY_LITTLE */ - tcg_out_ldst_asi(s, data_reg, arg0, 0, STXA, ASI_PRIMARY_LITTLE); -#endif - break; - default: - tcg_abort(); - } - -#if defined(CONFIG_SOFTMMU) - /* label2: */ - *label2_ptr = (INSN_OP(0) | INSN_COND(COND_A, 0) | INSN_OP2(0x2) | - INSN_OFF22((unsigned long)s->code_ptr - - (unsigned long)label2_ptr)); -#endif -} - -static inline void tcg_out_op(TCGContext *s, int opc, const TCGArg *args, - const int *const_args) -{ - int c; - - switch (opc) { - case INDEX_op_exit_tb: - tcg_out_movi(s, TCG_TYPE_PTR, TCG_REG_I0, args[0]); - tcg_out32(s, JMPL | INSN_RD(TCG_REG_G0) | INSN_RS1(TCG_REG_I7) | - INSN_IMM13(8)); - tcg_out32(s, RESTORE | INSN_RD(TCG_REG_G0) | INSN_RS1(TCG_REG_G0) | - INSN_RS2(TCG_REG_G0)); - break; - case INDEX_op_goto_tb: - if (s->tb_jmp_offset) { - /* direct jump method */ - tcg_out_sethi(s, TCG_REG_I5, args[0] & 0xffffe000); - tcg_out32(s, JMPL | INSN_RD(TCG_REG_G0) | INSN_RS1(TCG_REG_I5) | - INSN_IMM13((args[0] & 0x1fff))); - s->tb_jmp_offset[args[0]] = s->code_ptr - s->code_buf; - } else { - /* indirect jump method */ - tcg_out_ld_ptr(s, TCG_REG_I5, (tcg_target_long)(s->tb_next + args[0])); - tcg_out32(s, JMPL | INSN_RD(TCG_REG_G0) | INSN_RS1(TCG_REG_I5) | - INSN_RS2(TCG_REG_G0)); - } - tcg_out_nop(s); - s->tb_next_offset[args[0]] = s->code_ptr - s->code_buf; - break; - case INDEX_op_call: - if (const_args[0]) - tcg_out32(s, CALL | ((((tcg_target_ulong)args[0] - - (tcg_target_ulong)s->code_ptr) >> 2) - & 0x3fffffff)); - else { - tcg_out_ld_ptr(s, TCG_REG_I5, - (tcg_target_long)(s->tb_next + args[0])); - tcg_out32(s, JMPL | INSN_RD(TCG_REG_O7) | INSN_RS1(TCG_REG_I5) | - INSN_RS2(TCG_REG_G0)); - } - /* Store AREG0 in stack to avoid ugly glibc bugs that mangle - global registers */ - // delay slot - tcg_out_ldst(s, TCG_AREG0, TCG_REG_CALL_STACK, - TCG_TARGET_CALL_STACK_OFFSET - TCG_STATIC_CALL_ARGS_SIZE - - sizeof(long), HOST_ST_OP); - tcg_out_ldst(s, TCG_AREG0, TCG_REG_CALL_STACK, - TCG_TARGET_CALL_STACK_OFFSET - TCG_STATIC_CALL_ARGS_SIZE - - sizeof(long), HOST_LD_OP); - break; - case INDEX_op_jmp: - case INDEX_op_br: - tcg_out_branch_i32(s, COND_A, args[0]); - tcg_out_nop(s); - break; - case INDEX_op_movi_i32: - tcg_out_movi(s, TCG_TYPE_I32, args[0], (uint32_t)args[1]); - break; - -#if TCG_TARGET_REG_BITS == 64 -#define OP_32_64(x) \ - glue(glue(case INDEX_op_, x), _i32): \ - glue(glue(case INDEX_op_, x), _i64) -#else -#define OP_32_64(x) \ - glue(glue(case INDEX_op_, x), _i32) -#endif - OP_32_64(ld8u): - tcg_out_ldst(s, args[0], args[1], args[2], LDUB); - break; - OP_32_64(ld8s): - tcg_out_ldst(s, args[0], args[1], args[2], LDSB); - break; - OP_32_64(ld16u): - tcg_out_ldst(s, args[0], args[1], args[2], LDUH); - break; - OP_32_64(ld16s): - tcg_out_ldst(s, args[0], args[1], args[2], LDSH); - break; - case INDEX_op_ld_i32: -#if TCG_TARGET_REG_BITS == 64 - case INDEX_op_ld32u_i64: -#endif - tcg_out_ldst(s, args[0], args[1], args[2], LDUW); - break; - OP_32_64(st8): - tcg_out_ldst(s, args[0], args[1], args[2], STB); - break; - OP_32_64(st16): - tcg_out_ldst(s, args[0], args[1], args[2], STH); - break; - case INDEX_op_st_i32: -#if TCG_TARGET_REG_BITS == 64 - case INDEX_op_st32_i64: -#endif - tcg_out_ldst(s, args[0], args[1], args[2], STW); - break; - OP_32_64(add): - c = ARITH_ADD; - goto gen_arith; - OP_32_64(sub): - c = ARITH_SUB; - goto gen_arith; - OP_32_64(and): - c = ARITH_AND; - goto gen_arith; - OP_32_64(or): - c = ARITH_OR; - goto gen_arith; - OP_32_64(xor): - c = ARITH_XOR; - goto gen_arith; - case INDEX_op_shl_i32: - c = SHIFT_SLL; - goto gen_arith; - case INDEX_op_shr_i32: - c = SHIFT_SRL; - goto gen_arith; - case INDEX_op_sar_i32: - c = SHIFT_SRA; - goto gen_arith; - case INDEX_op_mul_i32: - c = ARITH_UMUL; - goto gen_arith; - - case INDEX_op_div_i32: - tcg_out_div32(s, args[0], args[1], args[2], const_args[2], 0); - break; - case INDEX_op_divu_i32: - tcg_out_div32(s, args[0], args[1], args[2], const_args[2], 1); - break; - - case INDEX_op_rem_i32: - case INDEX_op_remu_i32: - tcg_out_div32(s, TCG_REG_I5, args[1], args[2], const_args[2], - opc == INDEX_op_remu_i32); - tcg_out_arithc(s, TCG_REG_I5, TCG_REG_I5, args[2], const_args[2], - ARITH_UMUL); - tcg_out_arith(s, args[0], args[1], TCG_REG_I5, ARITH_SUB); - break; - - case INDEX_op_brcond_i32: - tcg_out_brcond_i32(s, args[2], args[0], args[1], const_args[1], - args[3]); - break; -#if TCG_TARGET_REG_BITS == 32 - case INDEX_op_brcond2_i32: - tcg_out_brcond2_i32(s, args[4], args[0], args[1], - args[2], const_args[2], - args[3], const_args[3], args[5]); - break; - case INDEX_op_add2_i32: - tcg_out_arithc(s, args[0], args[2], args[4], const_args[4], - ARITH_ADDCC); - tcg_out_arithc(s, args[1], args[3], args[5], const_args[5], - ARITH_ADDX); - break; - case INDEX_op_sub2_i32: - tcg_out_arithc(s, args[0], args[2], args[4], const_args[4], - ARITH_SUBCC); - tcg_out_arithc(s, args[1], args[3], args[5], const_args[5], - ARITH_SUBX); - break; - case INDEX_op_mulu2_i32: - tcg_out_arithc(s, args[0], args[2], args[3], const_args[3], - ARITH_UMUL); - tcg_out_rdy(s, args[1]); - break; -#endif - - case INDEX_op_qemu_ld8u: - tcg_out_qemu_ld(s, args, 0); - break; - case INDEX_op_qemu_ld8s: - tcg_out_qemu_ld(s, args, 0 | 4); - break; - case INDEX_op_qemu_ld16u: - tcg_out_qemu_ld(s, args, 1); - break; - case INDEX_op_qemu_ld16s: - tcg_out_qemu_ld(s, args, 1 | 4); - break; - case INDEX_op_qemu_ld32u: - tcg_out_qemu_ld(s, args, 2); - break; - case INDEX_op_qemu_ld32s: - tcg_out_qemu_ld(s, args, 2 | 4); - break; - case INDEX_op_qemu_st8: - tcg_out_qemu_st(s, args, 0); - break; - case INDEX_op_qemu_st16: - tcg_out_qemu_st(s, args, 1); - break; - case INDEX_op_qemu_st32: - tcg_out_qemu_st(s, args, 2); - break; - -#if TCG_TARGET_REG_BITS == 64 - case INDEX_op_movi_i64: - tcg_out_movi(s, TCG_TYPE_I64, args[0], args[1]); - break; - case INDEX_op_ld32s_i64: - tcg_out_ldst(s, args[0], args[1], args[2], LDSW); - break; - case INDEX_op_ld_i64: - tcg_out_ldst(s, args[0], args[1], args[2], LDX); - break; - case INDEX_op_st_i64: - tcg_out_ldst(s, args[0], args[1], args[2], STX); - break; - case INDEX_op_shl_i64: - c = SHIFT_SLLX; - goto gen_arith; - case INDEX_op_shr_i64: - c = SHIFT_SRLX; - goto gen_arith; - case INDEX_op_sar_i64: - c = SHIFT_SRAX; - goto gen_arith; - case INDEX_op_mul_i64: - c = ARITH_MULX; - goto gen_arith; - case INDEX_op_div_i64: - c = ARITH_SDIVX; - goto gen_arith; - case INDEX_op_divu_i64: - c = ARITH_UDIVX; - goto gen_arith; - case INDEX_op_rem_i64: - case INDEX_op_remu_i64: - tcg_out_arithc(s, TCG_REG_I5, args[1], args[2], const_args[2], - opc == INDEX_op_rem_i64 ? ARITH_SDIVX : ARITH_UDIVX); - tcg_out_arithc(s, TCG_REG_I5, TCG_REG_I5, args[2], const_args[2], - ARITH_MULX); - tcg_out_arith(s, args[0], args[1], TCG_REG_I5, ARITH_SUB); - break; - case INDEX_op_ext32s_i64: - if (const_args[1]) { - tcg_out_movi(s, TCG_TYPE_I64, args[0], (int32_t)args[1]); - } else { - tcg_out_arithi(s, args[0], args[1], 0, SHIFT_SRA); - } - break; - case INDEX_op_ext32u_i64: - if (const_args[1]) { - tcg_out_movi_imm32(s, args[0], args[1]); - } else { - tcg_out_arithi(s, args[0], args[1], 0, SHIFT_SRL); - } - break; - - case INDEX_op_brcond_i64: - tcg_out_brcond_i64(s, args[2], args[0], args[1], const_args[1], - args[3]); - break; - case INDEX_op_qemu_ld64: - tcg_out_qemu_ld(s, args, 3); - break; - case INDEX_op_qemu_st64: - tcg_out_qemu_st(s, args, 3); - break; - -#endif - gen_arith: - tcg_out_arithc(s, args[0], args[1], args[2], const_args[2], c); - break; - - default: - fprintf(stderr, "unknown opcode 0x%x\n", opc); - tcg_abort(); - } -} - -static const TCGTargetOpDef sparc_op_defs[] = { - { INDEX_op_exit_tb, { } }, - { INDEX_op_goto_tb, { } }, - { INDEX_op_call, { "ri" } }, - { INDEX_op_jmp, { "ri" } }, - { INDEX_op_br, { } }, - - { INDEX_op_mov_i32, { "r", "r" } }, - { INDEX_op_movi_i32, { "r" } }, - { INDEX_op_ld8u_i32, { "r", "r" } }, - { INDEX_op_ld8s_i32, { "r", "r" } }, - { INDEX_op_ld16u_i32, { "r", "r" } }, - { INDEX_op_ld16s_i32, { "r", "r" } }, - { INDEX_op_ld_i32, { "r", "r" } }, - { INDEX_op_st8_i32, { "r", "r" } }, - { INDEX_op_st16_i32, { "r", "r" } }, - { INDEX_op_st_i32, { "r", "r" } }, - - { INDEX_op_add_i32, { "r", "r", "rJ" } }, - { INDEX_op_mul_i32, { "r", "r", "rJ" } }, - { INDEX_op_div_i32, { "r", "r", "rJ" } }, - { INDEX_op_divu_i32, { "r", "r", "rJ" } }, - { INDEX_op_rem_i32, { "r", "r", "rJ" } }, - { INDEX_op_remu_i32, { "r", "r", "rJ" } }, - { INDEX_op_sub_i32, { "r", "r", "rJ" } }, - { INDEX_op_and_i32, { "r", "r", "rJ" } }, - { INDEX_op_or_i32, { "r", "r", "rJ" } }, - { INDEX_op_xor_i32, { "r", "r", "rJ" } }, - - { INDEX_op_shl_i32, { "r", "r", "rJ" } }, - { INDEX_op_shr_i32, { "r", "r", "rJ" } }, - { INDEX_op_sar_i32, { "r", "r", "rJ" } }, - - { INDEX_op_brcond_i32, { "r", "rJ" } }, -#if TCG_TARGET_REG_BITS == 32 - { INDEX_op_brcond2_i32, { "r", "r", "rJ", "rJ" } }, - { INDEX_op_add2_i32, { "r", "r", "r", "r", "rJ", "rJ" } }, - { INDEX_op_sub2_i32, { "r", "r", "r", "r", "rJ", "rJ" } }, - { INDEX_op_mulu2_i32, { "r", "r", "r", "rJ" } }, -#endif - - { INDEX_op_qemu_ld8u, { "r", "L" } }, - { INDEX_op_qemu_ld8s, { "r", "L" } }, - { INDEX_op_qemu_ld16u, { "r", "L" } }, - { INDEX_op_qemu_ld16s, { "r", "L" } }, - { INDEX_op_qemu_ld32u, { "r", "L" } }, - { INDEX_op_qemu_ld32s, { "r", "L" } }, - - { INDEX_op_qemu_st8, { "L", "L" } }, - { INDEX_op_qemu_st16, { "L", "L" } }, - { INDEX_op_qemu_st32, { "L", "L" } }, - -#if TCG_TARGET_REG_BITS == 64 - { INDEX_op_mov_i64, { "r", "r" } }, - { INDEX_op_movi_i64, { "r" } }, - { INDEX_op_ld8u_i64, { "r", "r" } }, - { INDEX_op_ld8s_i64, { "r", "r" } }, - { INDEX_op_ld16u_i64, { "r", "r" } }, - { INDEX_op_ld16s_i64, { "r", "r" } }, - { INDEX_op_ld32u_i64, { "r", "r" } }, - { INDEX_op_ld32s_i64, { "r", "r" } }, - { INDEX_op_ld_i64, { "r", "r" } }, - { INDEX_op_st8_i64, { "r", "r" } }, - { INDEX_op_st16_i64, { "r", "r" } }, - { INDEX_op_st32_i64, { "r", "r" } }, - { INDEX_op_st_i64, { "r", "r" } }, - { INDEX_op_qemu_ld64, { "L", "L" } }, - { INDEX_op_qemu_st64, { "L", "L" } }, - - { INDEX_op_add_i64, { "r", "r", "rJ" } }, - { INDEX_op_mul_i64, { "r", "r", "rJ" } }, - { INDEX_op_div_i64, { "r", "r", "rJ" } }, - { INDEX_op_divu_i64, { "r", "r", "rJ" } }, - { INDEX_op_rem_i64, { "r", "r", "rJ" } }, - { INDEX_op_remu_i64, { "r", "r", "rJ" } }, - { INDEX_op_sub_i64, { "r", "r", "rJ" } }, - { INDEX_op_and_i64, { "r", "r", "rJ" } }, - { INDEX_op_or_i64, { "r", "r", "rJ" } }, - { INDEX_op_xor_i64, { "r", "r", "rJ" } }, - - { INDEX_op_shl_i64, { "r", "r", "rJ" } }, - { INDEX_op_shr_i64, { "r", "r", "rJ" } }, - { INDEX_op_sar_i64, { "r", "r", "rJ" } }, - { INDEX_op_ext32s_i64, { "r", "ri" } }, - { INDEX_op_ext32u_i64, { "r", "ri" } }, - - { INDEX_op_brcond_i64, { "r", "rJ" } }, -#endif - { -1 }, -}; - -void tcg_target_init(TCGContext *s) -{ - tcg_regset_set32(tcg_target_available_regs[TCG_TYPE_I32], 0, 0xffffffff); -#if TCG_TARGET_REG_BITS == 64 - tcg_regset_set32(tcg_target_available_regs[TCG_TYPE_I64], 0, 0xffffffff); -#endif - tcg_regset_set32(tcg_target_call_clobber_regs, 0, - (1 << TCG_REG_G1) | - (1 << TCG_REG_G2) | - (1 << TCG_REG_G3) | - (1 << TCG_REG_G4) | - (1 << TCG_REG_G5) | - (1 << TCG_REG_G6) | - (1 << TCG_REG_G7) | - (1 << TCG_REG_O0) | - (1 << TCG_REG_O1) | - (1 << TCG_REG_O2) | - (1 << TCG_REG_O3) | - (1 << TCG_REG_O4) | - (1 << TCG_REG_O5) | - (1 << TCG_REG_O7)); - - tcg_regset_clear(s->reserved_regs); - tcg_regset_set_reg(s->reserved_regs, TCG_REG_G0); -#if TCG_TARGET_REG_BITS == 64 - tcg_regset_set_reg(s->reserved_regs, TCG_REG_I4); // for internal use -#endif - tcg_regset_set_reg(s->reserved_regs, TCG_REG_I5); // for internal use - tcg_regset_set_reg(s->reserved_regs, TCG_REG_I6); - tcg_regset_set_reg(s->reserved_regs, TCG_REG_I7); - tcg_regset_set_reg(s->reserved_regs, TCG_REG_O6); - tcg_regset_set_reg(s->reserved_regs, TCG_REG_O7); - tcg_add_target_add_op_defs(sparc_op_defs); -} diff --git a/qemu/qemu-git/tcg/sparc/.svn/text-base/tcg-target.h.svn-base b/qemu/qemu-git/tcg/sparc/.svn/text-base/tcg-target.h.svn-base deleted file mode 100644 index d27ed5a..0000000 --- a/qemu/qemu-git/tcg/sparc/.svn/text-base/tcg-target.h.svn-base +++ /dev/null @@ -1,129 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2008 Fabrice Bellard - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ -#define TCG_TARGET_SPARC 1 - -#if defined(__sparc_v9__) && !defined(__sparc_v8plus__) -#define TCG_TARGET_REG_BITS 64 -#else -#define TCG_TARGET_REG_BITS 32 -#endif - -#define TCG_TARGET_WORDS_BIGENDIAN - -#define TCG_TARGET_NB_REGS 32 - -enum { - TCG_REG_G0 = 0, - TCG_REG_G1, - TCG_REG_G2, - TCG_REG_G3, - TCG_REG_G4, - TCG_REG_G5, - TCG_REG_G6, - TCG_REG_G7, - TCG_REG_O0, - TCG_REG_O1, - TCG_REG_O2, - TCG_REG_O3, - TCG_REG_O4, - TCG_REG_O5, - TCG_REG_O6, - TCG_REG_O7, - TCG_REG_L0, - TCG_REG_L1, - TCG_REG_L2, - TCG_REG_L3, - TCG_REG_L4, - TCG_REG_L5, - TCG_REG_L6, - TCG_REG_L7, - TCG_REG_I0, - TCG_REG_I1, - TCG_REG_I2, - TCG_REG_I3, - TCG_REG_I4, - TCG_REG_I5, - TCG_REG_I6, - TCG_REG_I7, -}; - -#define TCG_CT_CONST_S11 0x100 -#define TCG_CT_CONST_S13 0x200 - -/* used for function call generation */ -#define TCG_REG_CALL_STACK TCG_REG_I6 -#ifdef __arch64__ -// Reserve space for AREG0 -#define TCG_TARGET_STACK_MINFRAME (176 + 4 * (int)sizeof(long) + \ - TCG_STATIC_CALL_ARGS_SIZE) -#define TCG_TARGET_CALL_STACK_OFFSET (2047 - 16) -#define TCG_TARGET_STACK_ALIGN 16 -#else -// AREG0 + one word for alignment -#define TCG_TARGET_STACK_MINFRAME (92 + (2 + 1) * (int)sizeof(long) + \ - TCG_STATIC_CALL_ARGS_SIZE) -#define TCG_TARGET_CALL_STACK_OFFSET TCG_TARGET_STACK_MINFRAME -#define TCG_TARGET_STACK_ALIGN 8 -#endif - -/* optional instructions */ -#define TCG_TARGET_HAS_div_i32 -#define TCG_TARGET_HAS_div_i64 - -#if TCG_TARGET_REG_BITS == 64 -#define TCG_TARGET_HAS_ext32s_i64 -#define TCG_TARGET_HAS_ext32u_i64 -#endif - -//#define TCG_TARGET_HAS_bswap32_i32 -//#define TCG_TARGET_HAS_bswap64_i64 -//#define TCG_TARGET_HAS_neg_i32 -//#define TCG_TARGET_HAS_neg_i64 - - -/* Note: must be synced with dyngen-exec.h and Makefile.target */ -#ifdef CONFIG_SOLARIS -#define TCG_AREG0 TCG_REG_G2 -#define TCG_AREG1 TCG_REG_G3 -#define TCG_AREG2 TCG_REG_G4 -#elif defined(__sparc_v9__) -#define TCG_AREG0 TCG_REG_G5 -#define TCG_AREG1 TCG_REG_G6 -#define TCG_AREG2 TCG_REG_G7 -#else -#define TCG_AREG0 TCG_REG_G6 -#define TCG_AREG1 TCG_REG_G1 -#define TCG_AREG2 TCG_REG_G2 -#endif - -static inline void flush_icache_range(unsigned long start, unsigned long stop) -{ - unsigned long p; - - p = start & ~(8UL - 1UL); - stop = (stop + (8UL - 1UL)) & ~(8UL - 1UL); - - for (; p < stop; p += 8) - __asm__ __volatile__("flush\t%0" : : "r" (p)); -} diff --git a/qemu/qemu-git/tcg/x86_64/.svn/all-wcprops b/qemu/qemu-git/tcg/x86_64/.svn/all-wcprops deleted file mode 100644 index 682e45d..0000000 --- a/qemu/qemu-git/tcg/x86_64/.svn/all-wcprops +++ /dev/null @@ -1,17 +0,0 @@ -K 25 -svn:wc:ra_dav:version-url -V 50 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/x86_64 -END -tcg-target.c -K 25 -svn:wc:ra_dav:version-url -V 63 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/x86_64/tcg-target.c -END -tcg-target.h -K 25 -svn:wc:ra_dav:version-url -V 63 -/p/x49gp/code/!svn/ver/10/qemu/qemu-git/tcg/x86_64/tcg-target.h -END diff --git a/qemu/qemu-git/tcg/x86_64/.svn/entries b/qemu/qemu-git/tcg/x86_64/.svn/entries deleted file mode 100644 index fb06525..0000000 --- a/qemu/qemu-git/tcg/x86_64/.svn/entries +++ /dev/null @@ -1,96 +0,0 @@ -10 - -dir -11 -http://svn.code.sf.net/p/x49gp/code/qemu/qemu-git/tcg/x86_64 -http://svn.code.sf.net/p/x49gp/code - - - -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - -481df3bd-3408-496c-b7de-451e46197bb5 - -tcg-target.c -file - - - - -2013-08-23T00:54:47.000000Z -d3f45a7da549459996584a45dd0890e2 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -41621 - -tcg-target.h -file - - - - -2013-08-23T00:54:47.000000Z -1838eb6151ae652ab32eec55d0b3a066 -2010-04-24T23:27:43.537348Z -10 -datajerk - - - - - - - - - - - - - - - - - - - - - -2768 - diff --git a/qemu/qemu-git/tcg/x86_64/.svn/text-base/tcg-target.c.svn-base b/qemu/qemu-git/tcg/x86_64/.svn/text-base/tcg-target.c.svn-base deleted file mode 100644 index cbaabef..0000000 --- a/qemu/qemu-git/tcg/x86_64/.svn/text-base/tcg-target.c.svn-base +++ /dev/null @@ -1,1422 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2008 Fabrice Bellard - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ - -#ifndef NDEBUG -static const char * const tcg_target_reg_names[TCG_TARGET_NB_REGS] = { - "%rax", - "%rcx", - "%rdx", - "%rbx", - "%rsp", - "%rbp", - "%rsi", - "%rdi", - "%r8", - "%r9", - "%r10", - "%r11", - "%r12", - "%r13", - "%r14", - "%r15", -}; -#endif - -static const int tcg_target_reg_alloc_order[] = { - TCG_REG_RBP, - TCG_REG_RBX, - TCG_REG_R12, - TCG_REG_R13, - TCG_REG_R14, - TCG_REG_R15, - TCG_REG_R10, - TCG_REG_R11, - TCG_REG_R9, - TCG_REG_R8, - TCG_REG_RCX, - TCG_REG_RDX, - TCG_REG_RSI, - TCG_REG_RDI, - TCG_REG_RAX, -}; - -static const int tcg_target_call_iarg_regs[6] = { - TCG_REG_RDI, - TCG_REG_RSI, - TCG_REG_RDX, - TCG_REG_RCX, - TCG_REG_R8, - TCG_REG_R9, -}; - -static const int tcg_target_call_oarg_regs[2] = { - TCG_REG_RAX, - TCG_REG_RDX -}; - -static uint8_t *tb_ret_addr; - -static void patch_reloc(uint8_t *code_ptr, int type, - tcg_target_long value, tcg_target_long addend) -{ - value += addend; - switch(type) { - case R_X86_64_32: - if (value != (uint32_t)value) - tcg_abort(); - *(uint32_t *)code_ptr = value; - break; - case R_X86_64_32S: - if (value != (int32_t)value) - tcg_abort(); - *(uint32_t *)code_ptr = value; - break; - case R_386_PC32: - value -= (long)code_ptr; - if (value != (int32_t)value) - tcg_abort(); - *(uint32_t *)code_ptr = value; - break; - default: - tcg_abort(); - } -} - -/* maximum number of register used for input function arguments */ -static inline int tcg_target_get_call_iarg_regs_count(int flags) -{ - return 6; -} - -/* parse target specific constraints */ -static int target_parse_constraint(TCGArgConstraint *ct, const char **pct_str) -{ - const char *ct_str; - - ct_str = *pct_str; - switch(ct_str[0]) { - case 'a': - ct->ct |= TCG_CT_REG; - tcg_regset_set_reg(ct->u.regs, TCG_REG_RAX); - break; - case 'b': - ct->ct |= TCG_CT_REG; - tcg_regset_set_reg(ct->u.regs, TCG_REG_RBX); - break; - case 'c': - ct->ct |= TCG_CT_REG; - tcg_regset_set_reg(ct->u.regs, TCG_REG_RCX); - break; - case 'd': - ct->ct |= TCG_CT_REG; - tcg_regset_set_reg(ct->u.regs, TCG_REG_RDX); - break; - case 'S': - ct->ct |= TCG_CT_REG; - tcg_regset_set_reg(ct->u.regs, TCG_REG_RSI); - break; - case 'D': - ct->ct |= TCG_CT_REG; - tcg_regset_set_reg(ct->u.regs, TCG_REG_RDI); - break; - case 'q': - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, 0xf); - break; - case 'r': - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, 0xffff); - break; - case 'L': /* qemu_ld/st constraint */ - ct->ct |= TCG_CT_REG; - tcg_regset_set32(ct->u.regs, 0, 0xffff); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_RSI); - tcg_regset_reset_reg(ct->u.regs, TCG_REG_RDI); - break; - case 'e': - ct->ct |= TCG_CT_CONST_S32; - break; - case 'Z': - ct->ct |= TCG_CT_CONST_U32; - break; - default: - return -1; - } - ct_str++; - *pct_str = ct_str; - return 0; -} - -/* test if a constant matches the constraint */ -static inline int tcg_target_const_match(tcg_target_long val, - const TCGArgConstraint *arg_ct) -{ - int ct; - ct = arg_ct->ct; - if (ct & TCG_CT_CONST) - return 1; - else if ((ct & TCG_CT_CONST_S32) && val == (int32_t)val) - return 1; - else if ((ct & TCG_CT_CONST_U32) && val == (uint32_t)val) - return 1; - else - return 0; -} - -#define ARITH_ADD 0 -#define ARITH_OR 1 -#define ARITH_ADC 2 -#define ARITH_SBB 3 -#define ARITH_AND 4 -#define ARITH_SUB 5 -#define ARITH_XOR 6 -#define ARITH_CMP 7 - -#define SHIFT_ROL 0 -#define SHIFT_ROR 1 -#define SHIFT_SHL 4 -#define SHIFT_SHR 5 -#define SHIFT_SAR 7 - -#define JCC_JMP (-1) -#define JCC_JO 0x0 -#define JCC_JNO 0x1 -#define JCC_JB 0x2 -#define JCC_JAE 0x3 -#define JCC_JE 0x4 -#define JCC_JNE 0x5 -#define JCC_JBE 0x6 -#define JCC_JA 0x7 -#define JCC_JS 0x8 -#define JCC_JNS 0x9 -#define JCC_JP 0xa -#define JCC_JNP 0xb -#define JCC_JL 0xc -#define JCC_JGE 0xd -#define JCC_JLE 0xe -#define JCC_JG 0xf - -#define P_EXT 0x100 /* 0x0f opcode prefix */ -#define P_REXW 0x200 /* set rex.w = 1 */ -#define P_REXB_R 0x400 /* REG field as byte register */ -#define P_REXB_RM 0x800 /* R/M field as byte register */ - -static const uint8_t tcg_cond_to_jcc[10] = { - [TCG_COND_EQ] = JCC_JE, - [TCG_COND_NE] = JCC_JNE, - [TCG_COND_LT] = JCC_JL, - [TCG_COND_GE] = JCC_JGE, - [TCG_COND_LE] = JCC_JLE, - [TCG_COND_GT] = JCC_JG, - [TCG_COND_LTU] = JCC_JB, - [TCG_COND_GEU] = JCC_JAE, - [TCG_COND_LEU] = JCC_JBE, - [TCG_COND_GTU] = JCC_JA, -}; - -static void tcg_out_opc(TCGContext *s, int opc, int r, int rm, int x) -{ - int rex = 0; - - rex |= (opc & P_REXW) >> 6; /* REX.W */ - rex |= (r & 8) >> 1; /* REX.R */ - rex |= (x & 8) >> 2; /* REX.X */ - rex |= (rm & 8) >> 3; /* REX.B */ - - /* P_REXB_{R,RM} indicates that the given register is the low byte. - For %[abcd]l we need no REX prefix, but for %{si,di,bp,sp}l we do, - as otherwise the encoding indicates %[abcd]h. Note that the values - that are ORed in merely indicate that the REX byte must be present; - those bits get discarded in output. */ - rex |= opc & (r >= 4 ? P_REXB_R : 0); - rex |= opc & (rm >= 4 ? P_REXB_RM : 0); - - if (rex) { - tcg_out8(s, (uint8_t)(rex | 0x40)); - } - if (opc & P_EXT) { - tcg_out8(s, 0x0f); - } - tcg_out8(s, opc & 0xff); -} - -static inline void tcg_out_modrm(TCGContext *s, int opc, int r, int rm) -{ - tcg_out_opc(s, opc, r, rm, 0); - tcg_out8(s, 0xc0 | ((r & 7) << 3) | (rm & 7)); -} - -/* rm < 0 means no register index plus (-rm - 1 immediate bytes) */ -static inline void tcg_out_modrm_offset(TCGContext *s, int opc, int r, int rm, - tcg_target_long offset) -{ - if (rm < 0) { - tcg_target_long val; - tcg_out_opc(s, opc, r, 0, 0); - val = offset - ((tcg_target_long)s->code_ptr + 5 + (-rm - 1)); - if (val == (int32_t)val) { - /* eip relative */ - tcg_out8(s, 0x05 | ((r & 7) << 3)); - tcg_out32(s, val); - } else if (offset == (int32_t)offset) { - tcg_out8(s, 0x04 | ((r & 7) << 3)); - tcg_out8(s, 0x25); /* sib */ - tcg_out32(s, offset); - } else { - tcg_abort(); - } - } else if (offset == 0 && (rm & 7) != TCG_REG_RBP) { - tcg_out_opc(s, opc, r, rm, 0); - if ((rm & 7) == TCG_REG_RSP) { - tcg_out8(s, 0x04 | ((r & 7) << 3)); - tcg_out8(s, 0x24); - } else { - tcg_out8(s, 0x00 | ((r & 7) << 3) | (rm & 7)); - } - } else if ((int8_t)offset == offset) { - tcg_out_opc(s, opc, r, rm, 0); - if ((rm & 7) == TCG_REG_RSP) { - tcg_out8(s, 0x44 | ((r & 7) << 3)); - tcg_out8(s, 0x24); - } else { - tcg_out8(s, 0x40 | ((r & 7) << 3) | (rm & 7)); - } - tcg_out8(s, offset); - } else { - tcg_out_opc(s, opc, r, rm, 0); - if ((rm & 7) == TCG_REG_RSP) { - tcg_out8(s, 0x84 | ((r & 7) << 3)); - tcg_out8(s, 0x24); - } else { - tcg_out8(s, 0x80 | ((r & 7) << 3) | (rm & 7)); - } - tcg_out32(s, offset); - } -} - -#if defined(CONFIG_SOFTMMU) -/* XXX: incomplete. index must be different from ESP */ -static void tcg_out_modrm_offset2(TCGContext *s, int opc, int r, int rm, - int index, int shift, - tcg_target_long offset) -{ - int mod; - if (rm == -1) - tcg_abort(); - if (offset == 0 && (rm & 7) != TCG_REG_RBP) { - mod = 0; - } else if (offset == (int8_t)offset) { - mod = 0x40; - } else if (offset == (int32_t)offset) { - mod = 0x80; - } else { - tcg_abort(); - } - if (index == -1) { - tcg_out_opc(s, opc, r, rm, 0); - if ((rm & 7) == TCG_REG_RSP) { - tcg_out8(s, mod | ((r & 7) << 3) | 0x04); - tcg_out8(s, 0x04 | (rm & 7)); - } else { - tcg_out8(s, mod | ((r & 7) << 3) | (rm & 7)); - } - } else { - tcg_out_opc(s, opc, r, rm, index); - tcg_out8(s, mod | ((r & 7) << 3) | 0x04); - tcg_out8(s, (shift << 6) | ((index & 7) << 3) | (rm & 7)); - } - if (mod == 0x40) { - tcg_out8(s, offset); - } else if (mod == 0x80) { - tcg_out32(s, offset); - } -} -#endif - -static inline void tcg_out_mov(TCGContext *s, int ret, int arg) -{ - tcg_out_modrm(s, 0x8b | P_REXW, ret, arg); -} - -static inline void tcg_out_movi(TCGContext *s, TCGType type, - int ret, tcg_target_long arg) -{ - if (arg == 0) { - tcg_out_modrm(s, 0x01 | (ARITH_XOR << 3), ret, ret); /* xor r0,r0 */ - } else if (arg == (uint32_t)arg || type == TCG_TYPE_I32) { - tcg_out_opc(s, 0xb8 + (ret & 7), 0, ret, 0); - tcg_out32(s, arg); - } else if (arg == (int32_t)arg) { - tcg_out_modrm(s, 0xc7 | P_REXW, 0, ret); - tcg_out32(s, arg); - } else { - tcg_out_opc(s, (0xb8 + (ret & 7)) | P_REXW, 0, ret, 0); - tcg_out32(s, arg); - tcg_out32(s, arg >> 32); - } -} - -static void tcg_out_goto(TCGContext *s, int call, uint8_t *target) -{ - int32_t disp; - - disp = target - s->code_ptr - 5; - if (disp == (target - s->code_ptr - 5)) { - tcg_out8(s, call ? 0xe8 : 0xe9); - tcg_out32(s, disp); - } else { - tcg_out_movi(s, TCG_TYPE_PTR, TCG_REG_R10, (tcg_target_long) target); - tcg_out_modrm(s, 0xff, call ? 2 : 4, TCG_REG_R10); - } -} - -static inline void tcg_out_ld(TCGContext *s, TCGType type, int ret, - int arg1, tcg_target_long arg2) -{ - if (type == TCG_TYPE_I32) - tcg_out_modrm_offset(s, 0x8b, ret, arg1, arg2); /* movl */ - else - tcg_out_modrm_offset(s, 0x8b | P_REXW, ret, arg1, arg2); /* movq */ -} - -static inline void tcg_out_st(TCGContext *s, TCGType type, int arg, - int arg1, tcg_target_long arg2) -{ - if (type == TCG_TYPE_I32) - tcg_out_modrm_offset(s, 0x89, arg, arg1, arg2); /* movl */ - else - tcg_out_modrm_offset(s, 0x89 | P_REXW, arg, arg1, arg2); /* movq */ -} - -static inline void tgen_arithi32(TCGContext *s, int c, int r0, int32_t val) -{ - if ((c == ARITH_ADD && val == 1) || (c == ARITH_SUB && val == -1)) { - /* inc */ - tcg_out_modrm(s, 0xff, 0, r0); - } else if ((c == ARITH_ADD && val == -1) || (c == ARITH_SUB && val == 1)) { - /* dec */ - tcg_out_modrm(s, 0xff, 1, r0); - } else if (val == (int8_t)val) { - tcg_out_modrm(s, 0x83, c, r0); - tcg_out8(s, val); - } else if (c == ARITH_AND && val == 0xffu) { - /* movzbl */ - tcg_out_modrm(s, 0xb6 | P_EXT | P_REXB_RM, r0, r0); - } else if (c == ARITH_AND && val == 0xffffu) { - /* movzwl */ - tcg_out_modrm(s, 0xb7 | P_EXT, r0, r0); - } else { - tcg_out_modrm(s, 0x81, c, r0); - tcg_out32(s, val); - } -} - -static inline void tgen_arithi64(TCGContext *s, int c, int r0, int64_t val) -{ - if ((c == ARITH_ADD && val == 1) || (c == ARITH_SUB && val == -1)) { - /* inc */ - tcg_out_modrm(s, 0xff | P_REXW, 0, r0); - } else if ((c == ARITH_ADD && val == -1) || (c == ARITH_SUB && val == 1)) { - /* dec */ - tcg_out_modrm(s, 0xff | P_REXW, 1, r0); - } else if (c == ARITH_AND && val == 0xffffffffu) { - /* 32-bit mov zero extends */ - tcg_out_modrm(s, 0x8b, r0, r0); - } else if (c == ARITH_AND && val == (uint32_t)val) { - /* AND with no high bits set can use a 32-bit operation. */ - tgen_arithi32(s, c, r0, (uint32_t)val); - } else if (val == (int8_t)val) { - tcg_out_modrm(s, 0x83 | P_REXW, c, r0); - tcg_out8(s, val); - } else if (val == (int32_t)val) { - tcg_out_modrm(s, 0x81 | P_REXW, c, r0); - tcg_out32(s, val); - } else { - tcg_abort(); - } -} - -static void tcg_out_addi(TCGContext *s, int reg, tcg_target_long val) -{ - if (val != 0) - tgen_arithi64(s, ARITH_ADD, reg, val); -} - -static void tcg_out_jxx(TCGContext *s, int opc, int label_index) -{ - int32_t val, val1; - TCGLabel *l = &s->labels[label_index]; - - if (l->has_value) { - val = l->u.value - (tcg_target_long)s->code_ptr; - val1 = val - 2; - if ((int8_t)val1 == val1) { - if (opc == -1) - tcg_out8(s, 0xeb); - else - tcg_out8(s, 0x70 + opc); - tcg_out8(s, val1); - } else { - if (opc == -1) { - tcg_out8(s, 0xe9); - tcg_out32(s, val - 5); - } else { - tcg_out8(s, 0x0f); - tcg_out8(s, 0x80 + opc); - tcg_out32(s, val - 6); - } - } - } else { - if (opc == -1) { - tcg_out8(s, 0xe9); - } else { - tcg_out8(s, 0x0f); - tcg_out8(s, 0x80 + opc); - } - tcg_out_reloc(s, s->code_ptr, R_386_PC32, label_index, -4); - s->code_ptr += 4; - } -} - -static void tcg_out_brcond(TCGContext *s, int cond, - TCGArg arg1, TCGArg arg2, int const_arg2, - int label_index, int rexw) -{ - if (const_arg2) { - if (arg2 == 0) { - /* test r, r */ - tcg_out_modrm(s, 0x85 | rexw, arg1, arg1); - } else { - if (rexw) - tgen_arithi64(s, ARITH_CMP, arg1, arg2); - else - tgen_arithi32(s, ARITH_CMP, arg1, arg2); - } - } else { - tcg_out_modrm(s, 0x01 | (ARITH_CMP << 3) | rexw, arg2, arg1); - } - tcg_out_jxx(s, tcg_cond_to_jcc[cond], label_index); -} - -#if defined(CONFIG_SOFTMMU) - -#include "../../softmmu_defs.h" - -static void *qemu_ld_helpers[4] = { - __ldb_mmu, - __ldw_mmu, - __ldl_mmu, - __ldq_mmu, -}; - -static void *qemu_st_helpers[4] = { - __stb_mmu, - __stw_mmu, - __stl_mmu, - __stq_mmu, -}; -#endif - -static void tcg_out_qemu_ld(TCGContext *s, const TCGArg *args, - int opc) -{ - int addr_reg, data_reg, r0, r1, mem_index, s_bits, bswap, rexw; - int32_t offset; -#if defined(CONFIG_SOFTMMU) - uint8_t *label1_ptr, *label2_ptr; -#endif - - data_reg = *args++; - addr_reg = *args++; - mem_index = *args; - s_bits = opc & 3; - - r0 = TCG_REG_RDI; - r1 = TCG_REG_RSI; - -#if TARGET_LONG_BITS == 32 - rexw = 0; -#else - rexw = P_REXW; -#endif -#if defined(CONFIG_SOFTMMU) - /* mov */ - tcg_out_modrm(s, 0x8b | rexw, r1, addr_reg); - - /* mov */ - tcg_out_modrm(s, 0x8b | rexw, r0, addr_reg); - - tcg_out_modrm(s, 0xc1 | rexw, 5, r1); /* shr $x, r1 */ - tcg_out8(s, TARGET_PAGE_BITS - CPU_TLB_ENTRY_BITS); - - tcg_out_modrm(s, 0x81 | rexw, 4, r0); /* andl $x, r0 */ - tcg_out32(s, TARGET_PAGE_MASK | ((1 << s_bits) - 1)); - - tcg_out_modrm(s, 0x81, 4, r1); /* andl $x, r1 */ - tcg_out32(s, (CPU_TLB_SIZE - 1) << CPU_TLB_ENTRY_BITS); - - /* lea offset(r1, env), r1 */ - tcg_out_modrm_offset2(s, 0x8d | P_REXW, r1, r1, TCG_AREG0, 0, - offsetof(CPUState, tlb_table[mem_index][0].addr_read)); - - /* cmp 0(r1), r0 */ - tcg_out_modrm_offset(s, 0x3b | rexw, r0, r1, 0); - - /* mov */ - tcg_out_modrm(s, 0x8b | rexw, r0, addr_reg); - - /* je label1 */ - tcg_out8(s, 0x70 + JCC_JE); - label1_ptr = s->code_ptr; - s->code_ptr++; - - /* XXX: move that code at the end of the TB */ - tcg_out_movi(s, TCG_TYPE_I32, TCG_REG_RSI, mem_index); - tcg_out_goto(s, 1, qemu_ld_helpers[s_bits]); - - switch(opc) { - case 0 | 4: - /* movsbq */ - tcg_out_modrm(s, 0xbe | P_EXT | P_REXW, data_reg, TCG_REG_RAX); - break; - case 1 | 4: - /* movswq */ - tcg_out_modrm(s, 0xbf | P_EXT | P_REXW, data_reg, TCG_REG_RAX); - break; - case 2 | 4: - /* movslq */ - tcg_out_modrm(s, 0x63 | P_REXW, data_reg, TCG_REG_RAX); - break; - case 0: - /* movzbq */ - tcg_out_modrm(s, 0xb6 | P_EXT | P_REXW, data_reg, TCG_REG_RAX); - break; - case 1: - /* movzwq */ - tcg_out_modrm(s, 0xb7 | P_EXT | P_REXW, data_reg, TCG_REG_RAX); - break; - case 2: - default: - /* movl */ - tcg_out_modrm(s, 0x8b, data_reg, TCG_REG_RAX); - break; - case 3: - tcg_out_mov(s, data_reg, TCG_REG_RAX); - break; - } - - /* jmp label2 */ - tcg_out8(s, 0xeb); - label2_ptr = s->code_ptr; - s->code_ptr++; - - /* label1: */ - *label1_ptr = s->code_ptr - label1_ptr - 1; - - /* add x(r1), r0 */ - tcg_out_modrm_offset(s, 0x03 | P_REXW, r0, r1, offsetof(CPUTLBEntry, addend) - - offsetof(CPUTLBEntry, addr_read)); - offset = 0; -#else - if (GUEST_BASE == (int32_t)GUEST_BASE) { - r0 = addr_reg; - offset = GUEST_BASE; - } else { - offset = 0; - /* movq $GUEST_BASE, r0 */ - tcg_out_opc(s, (0xb8 + (r0 & 7)) | P_REXW, 0, r0, 0); - tcg_out32(s, GUEST_BASE); - tcg_out32(s, GUEST_BASE >> 32); - /* addq addr_reg, r0 */ - tcg_out_modrm(s, 0x01 | P_REXW, addr_reg, r0); - } -#endif - -#ifdef TARGET_WORDS_BIGENDIAN - bswap = 1; -#else - bswap = 0; -#endif - switch(opc) { - case 0: - /* movzbl */ - tcg_out_modrm_offset(s, 0xb6 | P_EXT, data_reg, r0, offset); - break; - case 0 | 4: - /* movsbX */ - tcg_out_modrm_offset(s, 0xbe | P_EXT | rexw, data_reg, r0, offset); - break; - case 1: - /* movzwl */ - tcg_out_modrm_offset(s, 0xb7 | P_EXT, data_reg, r0, offset); - if (bswap) { - /* rolw $8, data_reg */ - tcg_out8(s, 0x66); - tcg_out_modrm(s, 0xc1, 0, data_reg); - tcg_out8(s, 8); - } - break; - case 1 | 4: - if (bswap) { - /* movzwl */ - tcg_out_modrm_offset(s, 0xb7 | P_EXT, data_reg, r0, offset); - /* rolw $8, data_reg */ - tcg_out8(s, 0x66); - tcg_out_modrm(s, 0xc1, 0, data_reg); - tcg_out8(s, 8); - - /* movswX data_reg, data_reg */ - tcg_out_modrm(s, 0xbf | P_EXT | rexw, data_reg, data_reg); - } else { - /* movswX */ - tcg_out_modrm_offset(s, 0xbf | P_EXT | rexw, data_reg, r0, offset); - } - break; - case 2: - /* movl (r0), data_reg */ - tcg_out_modrm_offset(s, 0x8b, data_reg, r0, offset); - if (bswap) { - /* bswap */ - tcg_out_opc(s, (0xc8 + (data_reg & 7)) | P_EXT, 0, data_reg, 0); - } - break; - case 2 | 4: - if (bswap) { - /* movl (r0), data_reg */ - tcg_out_modrm_offset(s, 0x8b, data_reg, r0, offset); - /* bswap */ - tcg_out_opc(s, (0xc8 + (data_reg & 7)) | P_EXT, 0, data_reg, 0); - /* movslq */ - tcg_out_modrm(s, 0x63 | P_REXW, data_reg, data_reg); - } else { - /* movslq */ - tcg_out_modrm_offset(s, 0x63 | P_REXW, data_reg, r0, offset); - } - break; - case 3: - /* movq (r0), data_reg */ - tcg_out_modrm_offset(s, 0x8b | P_REXW, data_reg, r0, offset); - if (bswap) { - /* bswap */ - tcg_out_opc(s, (0xc8 + (data_reg & 7)) | P_EXT | P_REXW, 0, data_reg, 0); - } - break; - default: - tcg_abort(); - } - -#if defined(CONFIG_SOFTMMU) - /* label2: */ - *label2_ptr = s->code_ptr - label2_ptr - 1; -#endif -} - -static void tcg_out_qemu_st(TCGContext *s, const TCGArg *args, - int opc) -{ - int addr_reg, data_reg, r0, r1, mem_index, s_bits, bswap, rexw; - int32_t offset; -#if defined(CONFIG_SOFTMMU) - uint8_t *label1_ptr, *label2_ptr; -#endif - - data_reg = *args++; - addr_reg = *args++; - mem_index = *args; - - s_bits = opc; - - r0 = TCG_REG_RDI; - r1 = TCG_REG_RSI; - -#if TARGET_LONG_BITS == 32 - rexw = 0; -#else - rexw = P_REXW; -#endif -#if defined(CONFIG_SOFTMMU) - /* mov */ - tcg_out_modrm(s, 0x8b | rexw, r1, addr_reg); - - /* mov */ - tcg_out_modrm(s, 0x8b | rexw, r0, addr_reg); - - tcg_out_modrm(s, 0xc1 | rexw, 5, r1); /* shr $x, r1 */ - tcg_out8(s, TARGET_PAGE_BITS - CPU_TLB_ENTRY_BITS); - - tcg_out_modrm(s, 0x81 | rexw, 4, r0); /* andl $x, r0 */ - tcg_out32(s, TARGET_PAGE_MASK | ((1 << s_bits) - 1)); - - tcg_out_modrm(s, 0x81, 4, r1); /* andl $x, r1 */ - tcg_out32(s, (CPU_TLB_SIZE - 1) << CPU_TLB_ENTRY_BITS); - - /* lea offset(r1, env), r1 */ - tcg_out_modrm_offset2(s, 0x8d | P_REXW, r1, r1, TCG_AREG0, 0, - offsetof(CPUState, tlb_table[mem_index][0].addr_write)); - - /* cmp 0(r1), r0 */ - tcg_out_modrm_offset(s, 0x3b | rexw, r0, r1, 0); - - /* mov */ - tcg_out_modrm(s, 0x8b | rexw, r0, addr_reg); - - /* je label1 */ - tcg_out8(s, 0x70 + JCC_JE); - label1_ptr = s->code_ptr; - s->code_ptr++; - - /* XXX: move that code at the end of the TB */ - switch(opc) { - case 0: - /* movzbl */ - tcg_out_modrm(s, 0xb6 | P_EXT | P_REXB_RM, TCG_REG_RSI, data_reg); - break; - case 1: - /* movzwl */ - tcg_out_modrm(s, 0xb7 | P_EXT, TCG_REG_RSI, data_reg); - break; - case 2: - /* movl */ - tcg_out_modrm(s, 0x8b, TCG_REG_RSI, data_reg); - break; - default: - case 3: - tcg_out_mov(s, TCG_REG_RSI, data_reg); - break; - } - tcg_out_movi(s, TCG_TYPE_I32, TCG_REG_RDX, mem_index); - tcg_out_goto(s, 1, qemu_st_helpers[s_bits]); - - /* jmp label2 */ - tcg_out8(s, 0xeb); - label2_ptr = s->code_ptr; - s->code_ptr++; - - /* label1: */ - *label1_ptr = s->code_ptr - label1_ptr - 1; - - /* add x(r1), r0 */ - tcg_out_modrm_offset(s, 0x03 | P_REXW, r0, r1, offsetof(CPUTLBEntry, addend) - - offsetof(CPUTLBEntry, addr_write)); - offset = 0; -#else - if (GUEST_BASE == (int32_t)GUEST_BASE) { - r0 = addr_reg; - offset = GUEST_BASE; - } else { - offset = 0; - /* movq $GUEST_BASE, r0 */ - tcg_out_opc(s, (0xb8 + (r0 & 7)) | P_REXW, 0, r0, 0); - tcg_out32(s, GUEST_BASE); - tcg_out32(s, GUEST_BASE >> 32); - /* addq addr_reg, r0 */ - tcg_out_modrm(s, 0x01 | P_REXW, addr_reg, r0); - } -#endif - -#ifdef TARGET_WORDS_BIGENDIAN - bswap = 1; -#else - bswap = 0; -#endif - switch(opc) { - case 0: - /* movb */ - tcg_out_modrm_offset(s, 0x88 | P_REXB_R, data_reg, r0, offset); - break; - case 1: - if (bswap) { - tcg_out_modrm(s, 0x8b, r1, data_reg); /* movl */ - tcg_out8(s, 0x66); /* rolw $8, %ecx */ - tcg_out_modrm(s, 0xc1, 0, r1); - tcg_out8(s, 8); - data_reg = r1; - } - /* movw */ - tcg_out8(s, 0x66); - tcg_out_modrm_offset(s, 0x89, data_reg, r0, offset); - break; - case 2: - if (bswap) { - tcg_out_modrm(s, 0x8b, r1, data_reg); /* movl */ - /* bswap data_reg */ - tcg_out_opc(s, (0xc8 + r1) | P_EXT, 0, r1, 0); - data_reg = r1; - } - /* movl */ - tcg_out_modrm_offset(s, 0x89, data_reg, r0, offset); - break; - case 3: - if (bswap) { - tcg_out_mov(s, r1, data_reg); - /* bswap data_reg */ - tcg_out_opc(s, (0xc8 + r1) | P_EXT | P_REXW, 0, r1, 0); - data_reg = r1; - } - /* movq */ - tcg_out_modrm_offset(s, 0x89 | P_REXW, data_reg, r0, offset); - break; - default: - tcg_abort(); - } - -#if defined(CONFIG_SOFTMMU) - /* label2: */ - *label2_ptr = s->code_ptr - label2_ptr - 1; -#endif -} - -static inline void tcg_out_op(TCGContext *s, int opc, const TCGArg *args, - const int *const_args) -{ - int c; - - switch(opc) { - case INDEX_op_exit_tb: - tcg_out_movi(s, TCG_TYPE_PTR, TCG_REG_RAX, args[0]); - tcg_out_goto(s, 0, tb_ret_addr); - break; - case INDEX_op_goto_tb: - if (s->tb_jmp_offset) { - /* direct jump method */ - tcg_out8(s, 0xe9); /* jmp im */ - s->tb_jmp_offset[args[0]] = s->code_ptr - s->code_buf; - tcg_out32(s, 0); - } else { - /* indirect jump method */ - /* jmp Ev */ - tcg_out_modrm_offset(s, 0xff, 4, -1, - (tcg_target_long)(s->tb_next + - args[0])); - } - s->tb_next_offset[args[0]] = s->code_ptr - s->code_buf; - break; - case INDEX_op_call: - if (const_args[0]) { - tcg_out_goto(s, 1, (void *) args[0]); - } else { - tcg_out_modrm(s, 0xff, 2, args[0]); - } - break; - case INDEX_op_jmp: - if (const_args[0]) { - tcg_out_goto(s, 0, (void *) args[0]); - } else { - tcg_out_modrm(s, 0xff, 4, args[0]); - } - break; - case INDEX_op_br: - tcg_out_jxx(s, JCC_JMP, args[0]); - break; - case INDEX_op_movi_i32: - tcg_out_movi(s, TCG_TYPE_I32, args[0], (uint32_t)args[1]); - break; - case INDEX_op_movi_i64: - tcg_out_movi(s, TCG_TYPE_I64, args[0], args[1]); - break; - case INDEX_op_ld8u_i32: - case INDEX_op_ld8u_i64: - /* movzbl */ - tcg_out_modrm_offset(s, 0xb6 | P_EXT, args[0], args[1], args[2]); - break; - case INDEX_op_ld8s_i32: - /* movsbl */ - tcg_out_modrm_offset(s, 0xbe | P_EXT, args[0], args[1], args[2]); - break; - case INDEX_op_ld8s_i64: - /* movsbq */ - tcg_out_modrm_offset(s, 0xbe | P_EXT | P_REXW, args[0], args[1], args[2]); - break; - case INDEX_op_ld16u_i32: - case INDEX_op_ld16u_i64: - /* movzwl */ - tcg_out_modrm_offset(s, 0xb7 | P_EXT, args[0], args[1], args[2]); - break; - case INDEX_op_ld16s_i32: - /* movswl */ - tcg_out_modrm_offset(s, 0xbf | P_EXT, args[0], args[1], args[2]); - break; - case INDEX_op_ld16s_i64: - /* movswq */ - tcg_out_modrm_offset(s, 0xbf | P_EXT | P_REXW, args[0], args[1], args[2]); - break; - case INDEX_op_ld_i32: - case INDEX_op_ld32u_i64: - /* movl */ - tcg_out_modrm_offset(s, 0x8b, args[0], args[1], args[2]); - break; - case INDEX_op_ld32s_i64: - /* movslq */ - tcg_out_modrm_offset(s, 0x63 | P_REXW, args[0], args[1], args[2]); - break; - case INDEX_op_ld_i64: - /* movq */ - tcg_out_modrm_offset(s, 0x8b | P_REXW, args[0], args[1], args[2]); - break; - - case INDEX_op_st8_i32: - case INDEX_op_st8_i64: - /* movb */ - tcg_out_modrm_offset(s, 0x88 | P_REXB_R, args[0], args[1], args[2]); - break; - case INDEX_op_st16_i32: - case INDEX_op_st16_i64: - /* movw */ - tcg_out8(s, 0x66); - tcg_out_modrm_offset(s, 0x89, args[0], args[1], args[2]); - break; - case INDEX_op_st_i32: - case INDEX_op_st32_i64: - /* movl */ - tcg_out_modrm_offset(s, 0x89, args[0], args[1], args[2]); - break; - case INDEX_op_st_i64: - /* movq */ - tcg_out_modrm_offset(s, 0x89 | P_REXW, args[0], args[1], args[2]); - break; - - case INDEX_op_sub_i32: - c = ARITH_SUB; - goto gen_arith32; - case INDEX_op_and_i32: - c = ARITH_AND; - goto gen_arith32; - case INDEX_op_or_i32: - c = ARITH_OR; - goto gen_arith32; - case INDEX_op_xor_i32: - c = ARITH_XOR; - goto gen_arith32; - case INDEX_op_add_i32: - c = ARITH_ADD; - gen_arith32: - if (const_args[2]) { - tgen_arithi32(s, c, args[0], args[2]); - } else { - tcg_out_modrm(s, 0x01 | (c << 3), args[2], args[0]); - } - break; - - case INDEX_op_sub_i64: - c = ARITH_SUB; - goto gen_arith64; - case INDEX_op_and_i64: - c = ARITH_AND; - goto gen_arith64; - case INDEX_op_or_i64: - c = ARITH_OR; - goto gen_arith64; - case INDEX_op_xor_i64: - c = ARITH_XOR; - goto gen_arith64; - case INDEX_op_add_i64: - c = ARITH_ADD; - gen_arith64: - if (const_args[2]) { - tgen_arithi64(s, c, args[0], args[2]); - } else { - tcg_out_modrm(s, 0x01 | (c << 3) | P_REXW, args[2], args[0]); - } - break; - - case INDEX_op_mul_i32: - if (const_args[2]) { - int32_t val; - val = args[2]; - if (val == (int8_t)val) { - tcg_out_modrm(s, 0x6b, args[0], args[0]); - tcg_out8(s, val); - } else { - tcg_out_modrm(s, 0x69, args[0], args[0]); - tcg_out32(s, val); - } - } else { - tcg_out_modrm(s, 0xaf | P_EXT, args[0], args[2]); - } - break; - case INDEX_op_mul_i64: - if (const_args[2]) { - int32_t val; - val = args[2]; - if (val == (int8_t)val) { - tcg_out_modrm(s, 0x6b | P_REXW, args[0], args[0]); - tcg_out8(s, val); - } else { - tcg_out_modrm(s, 0x69 | P_REXW, args[0], args[0]); - tcg_out32(s, val); - } - } else { - tcg_out_modrm(s, 0xaf | P_EXT | P_REXW, args[0], args[2]); - } - break; - case INDEX_op_div2_i32: - tcg_out_modrm(s, 0xf7, 7, args[4]); - break; - case INDEX_op_divu2_i32: - tcg_out_modrm(s, 0xf7, 6, args[4]); - break; - case INDEX_op_div2_i64: - tcg_out_modrm(s, 0xf7 | P_REXW, 7, args[4]); - break; - case INDEX_op_divu2_i64: - tcg_out_modrm(s, 0xf7 | P_REXW, 6, args[4]); - break; - - case INDEX_op_shl_i32: - c = SHIFT_SHL; - gen_shift32: - if (const_args[2]) { - if (args[2] == 1) { - tcg_out_modrm(s, 0xd1, c, args[0]); - } else { - tcg_out_modrm(s, 0xc1, c, args[0]); - tcg_out8(s, args[2]); - } - } else { - tcg_out_modrm(s, 0xd3, c, args[0]); - } - break; - case INDEX_op_shr_i32: - c = SHIFT_SHR; - goto gen_shift32; - case INDEX_op_sar_i32: - c = SHIFT_SAR; - goto gen_shift32; - case INDEX_op_rotl_i32: - c = SHIFT_ROL; - goto gen_shift32; - case INDEX_op_rotr_i32: - c = SHIFT_ROR; - goto gen_shift32; - - case INDEX_op_shl_i64: - c = SHIFT_SHL; - gen_shift64: - if (const_args[2]) { - if (args[2] == 1) { - tcg_out_modrm(s, 0xd1 | P_REXW, c, args[0]); - } else { - tcg_out_modrm(s, 0xc1 | P_REXW, c, args[0]); - tcg_out8(s, args[2]); - } - } else { - tcg_out_modrm(s, 0xd3 | P_REXW, c, args[0]); - } - break; - case INDEX_op_shr_i64: - c = SHIFT_SHR; - goto gen_shift64; - case INDEX_op_sar_i64: - c = SHIFT_SAR; - goto gen_shift64; - case INDEX_op_rotl_i64: - c = SHIFT_ROL; - goto gen_shift64; - case INDEX_op_rotr_i64: - c = SHIFT_ROR; - goto gen_shift64; - - case INDEX_op_brcond_i32: - tcg_out_brcond(s, args[2], args[0], args[1], const_args[1], - args[3], 0); - break; - case INDEX_op_brcond_i64: - tcg_out_brcond(s, args[2], args[0], args[1], const_args[1], - args[3], P_REXW); - break; - - case INDEX_op_bswap16_i32: - case INDEX_op_bswap16_i64: - tcg_out8(s, 0x66); - tcg_out_modrm(s, 0xc1, SHIFT_ROL, args[0]); - tcg_out8(s, 8); - break; - case INDEX_op_bswap32_i32: - case INDEX_op_bswap32_i64: - tcg_out_opc(s, (0xc8 + (args[0] & 7)) | P_EXT, 0, args[0], 0); - break; - case INDEX_op_bswap64_i64: - tcg_out_opc(s, (0xc8 + (args[0] & 7)) | P_EXT | P_REXW, 0, args[0], 0); - break; - - case INDEX_op_neg_i32: - tcg_out_modrm(s, 0xf7, 3, args[0]); - break; - case INDEX_op_neg_i64: - tcg_out_modrm(s, 0xf7 | P_REXW, 3, args[0]); - break; - - case INDEX_op_not_i32: - tcg_out_modrm(s, 0xf7, 2, args[0]); - break; - case INDEX_op_not_i64: - tcg_out_modrm(s, 0xf7 | P_REXW, 2, args[0]); - break; - - case INDEX_op_ext8s_i32: - tcg_out_modrm(s, 0xbe | P_EXT | P_REXB_RM, args[0], args[1]); - break; - case INDEX_op_ext16s_i32: - tcg_out_modrm(s, 0xbf | P_EXT, args[0], args[1]); - break; - case INDEX_op_ext8s_i64: - tcg_out_modrm(s, 0xbe | P_EXT | P_REXW, args[0], args[1]); - break; - case INDEX_op_ext16s_i64: - tcg_out_modrm(s, 0xbf | P_EXT | P_REXW, args[0], args[1]); - break; - case INDEX_op_ext32s_i64: - tcg_out_modrm(s, 0x63 | P_REXW, args[0], args[1]); - break; - case INDEX_op_ext8u_i32: - case INDEX_op_ext8u_i64: - tcg_out_modrm(s, 0xb6 | P_EXT | P_REXB_RM, args[0], args[1]); - break; - case INDEX_op_ext16u_i32: - case INDEX_op_ext16u_i64: - tcg_out_modrm(s, 0xb7 | P_EXT, args[0], args[1]); - break; - case INDEX_op_ext32u_i64: - tcg_out_modrm(s, 0x8b, args[0], args[1]); - break; - - case INDEX_op_qemu_ld8u: - tcg_out_qemu_ld(s, args, 0); - break; - case INDEX_op_qemu_ld8s: - tcg_out_qemu_ld(s, args, 0 | 4); - break; - case INDEX_op_qemu_ld16u: - tcg_out_qemu_ld(s, args, 1); - break; - case INDEX_op_qemu_ld16s: - tcg_out_qemu_ld(s, args, 1 | 4); - break; - case INDEX_op_qemu_ld32u: - tcg_out_qemu_ld(s, args, 2); - break; - case INDEX_op_qemu_ld32s: - tcg_out_qemu_ld(s, args, 2 | 4); - break; - case INDEX_op_qemu_ld64: - tcg_out_qemu_ld(s, args, 3); - break; - - case INDEX_op_qemu_st8: - tcg_out_qemu_st(s, args, 0); - break; - case INDEX_op_qemu_st16: - tcg_out_qemu_st(s, args, 1); - break; - case INDEX_op_qemu_st32: - tcg_out_qemu_st(s, args, 2); - break; - case INDEX_op_qemu_st64: - tcg_out_qemu_st(s, args, 3); - break; - - default: - tcg_abort(); - } -} - -static int tcg_target_callee_save_regs[] = { - TCG_REG_RBP, - TCG_REG_RBX, - TCG_REG_R12, - TCG_REG_R13, - /* TCG_REG_R14, */ /* currently used for the global env, so no - need to save */ - TCG_REG_R15, -}; - -static inline void tcg_out_push(TCGContext *s, int reg) -{ - tcg_out_opc(s, (0x50 + (reg & 7)), 0, reg, 0); -} - -static inline void tcg_out_pop(TCGContext *s, int reg) -{ - tcg_out_opc(s, (0x58 + (reg & 7)), 0, reg, 0); -} - -/* Generate global QEMU prologue and epilogue code */ -void tcg_target_qemu_prologue(TCGContext *s) -{ - int i, frame_size, push_size, stack_addend; - - /* TB prologue */ - /* save all callee saved registers */ - for(i = 0; i < ARRAY_SIZE(tcg_target_callee_save_regs); i++) { - tcg_out_push(s, tcg_target_callee_save_regs[i]); - - } - /* reserve some stack space */ - push_size = 8 + ARRAY_SIZE(tcg_target_callee_save_regs) * 8; - frame_size = push_size + TCG_STATIC_CALL_ARGS_SIZE; - frame_size = (frame_size + TCG_TARGET_STACK_ALIGN - 1) & - ~(TCG_TARGET_STACK_ALIGN - 1); - stack_addend = frame_size - push_size; - tcg_out_addi(s, TCG_REG_RSP, -stack_addend); - - tcg_out_modrm(s, 0xff, 4, TCG_REG_RDI); /* jmp *%rdi */ - - /* TB epilogue */ - tb_ret_addr = s->code_ptr; - tcg_out_addi(s, TCG_REG_RSP, stack_addend); - for(i = ARRAY_SIZE(tcg_target_callee_save_regs) - 1; i >= 0; i--) { - tcg_out_pop(s, tcg_target_callee_save_regs[i]); - } - tcg_out8(s, 0xc3); /* ret */ -} - -static const TCGTargetOpDef x86_64_op_defs[] = { - { INDEX_op_exit_tb, { } }, - { INDEX_op_goto_tb, { } }, - { INDEX_op_call, { "ri" } }, /* XXX: might need a specific constant constraint */ - { INDEX_op_jmp, { "ri" } }, /* XXX: might need a specific constant constraint */ - { INDEX_op_br, { } }, - - { INDEX_op_mov_i32, { "r", "r" } }, - { INDEX_op_movi_i32, { "r" } }, - { INDEX_op_ld8u_i32, { "r", "r" } }, - { INDEX_op_ld8s_i32, { "r", "r" } }, - { INDEX_op_ld16u_i32, { "r", "r" } }, - { INDEX_op_ld16s_i32, { "r", "r" } }, - { INDEX_op_ld_i32, { "r", "r" } }, - { INDEX_op_st8_i32, { "r", "r" } }, - { INDEX_op_st16_i32, { "r", "r" } }, - { INDEX_op_st_i32, { "r", "r" } }, - - { INDEX_op_add_i32, { "r", "0", "ri" } }, - { INDEX_op_mul_i32, { "r", "0", "ri" } }, - { INDEX_op_div2_i32, { "a", "d", "0", "1", "r" } }, - { INDEX_op_divu2_i32, { "a", "d", "0", "1", "r" } }, - { INDEX_op_sub_i32, { "r", "0", "ri" } }, - { INDEX_op_and_i32, { "r", "0", "ri" } }, - { INDEX_op_or_i32, { "r", "0", "ri" } }, - { INDEX_op_xor_i32, { "r", "0", "ri" } }, - - { INDEX_op_shl_i32, { "r", "0", "ci" } }, - { INDEX_op_shr_i32, { "r", "0", "ci" } }, - { INDEX_op_sar_i32, { "r", "0", "ci" } }, - { INDEX_op_rotl_i32, { "r", "0", "ci" } }, - { INDEX_op_rotr_i32, { "r", "0", "ci" } }, - - { INDEX_op_brcond_i32, { "r", "ri" } }, - - { INDEX_op_mov_i64, { "r", "r" } }, - { INDEX_op_movi_i64, { "r" } }, - { INDEX_op_ld8u_i64, { "r", "r" } }, - { INDEX_op_ld8s_i64, { "r", "r" } }, - { INDEX_op_ld16u_i64, { "r", "r" } }, - { INDEX_op_ld16s_i64, { "r", "r" } }, - { INDEX_op_ld32u_i64, { "r", "r" } }, - { INDEX_op_ld32s_i64, { "r", "r" } }, - { INDEX_op_ld_i64, { "r", "r" } }, - { INDEX_op_st8_i64, { "r", "r" } }, - { INDEX_op_st16_i64, { "r", "r" } }, - { INDEX_op_st32_i64, { "r", "r" } }, - { INDEX_op_st_i64, { "r", "r" } }, - - { INDEX_op_add_i64, { "r", "0", "re" } }, - { INDEX_op_mul_i64, { "r", "0", "re" } }, - { INDEX_op_div2_i64, { "a", "d", "0", "1", "r" } }, - { INDEX_op_divu2_i64, { "a", "d", "0", "1", "r" } }, - { INDEX_op_sub_i64, { "r", "0", "re" } }, - { INDEX_op_and_i64, { "r", "0", "reZ" } }, - { INDEX_op_or_i64, { "r", "0", "re" } }, - { INDEX_op_xor_i64, { "r", "0", "re" } }, - - { INDEX_op_shl_i64, { "r", "0", "ci" } }, - { INDEX_op_shr_i64, { "r", "0", "ci" } }, - { INDEX_op_sar_i64, { "r", "0", "ci" } }, - { INDEX_op_rotl_i64, { "r", "0", "ci" } }, - { INDEX_op_rotr_i64, { "r", "0", "ci" } }, - - { INDEX_op_brcond_i64, { "r", "re" } }, - - { INDEX_op_bswap16_i32, { "r", "0" } }, - { INDEX_op_bswap16_i64, { "r", "0" } }, - { INDEX_op_bswap32_i32, { "r", "0" } }, - { INDEX_op_bswap32_i64, { "r", "0" } }, - { INDEX_op_bswap64_i64, { "r", "0" } }, - - { INDEX_op_neg_i32, { "r", "0" } }, - { INDEX_op_neg_i64, { "r", "0" } }, - - { INDEX_op_not_i32, { "r", "0" } }, - { INDEX_op_not_i64, { "r", "0" } }, - - { INDEX_op_ext8s_i32, { "r", "r"} }, - { INDEX_op_ext16s_i32, { "r", "r"} }, - { INDEX_op_ext8s_i64, { "r", "r"} }, - { INDEX_op_ext16s_i64, { "r", "r"} }, - { INDEX_op_ext32s_i64, { "r", "r"} }, - { INDEX_op_ext8u_i32, { "r", "r"} }, - { INDEX_op_ext16u_i32, { "r", "r"} }, - { INDEX_op_ext8u_i64, { "r", "r"} }, - { INDEX_op_ext16u_i64, { "r", "r"} }, - { INDEX_op_ext32u_i64, { "r", "r"} }, - - { INDEX_op_qemu_ld8u, { "r", "L" } }, - { INDEX_op_qemu_ld8s, { "r", "L" } }, - { INDEX_op_qemu_ld16u, { "r", "L" } }, - { INDEX_op_qemu_ld16s, { "r", "L" } }, - { INDEX_op_qemu_ld32u, { "r", "L" } }, - { INDEX_op_qemu_ld32s, { "r", "L" } }, - { INDEX_op_qemu_ld64, { "r", "L" } }, - - { INDEX_op_qemu_st8, { "L", "L" } }, - { INDEX_op_qemu_st16, { "L", "L" } }, - { INDEX_op_qemu_st32, { "L", "L" } }, - { INDEX_op_qemu_st64, { "L", "L" } }, - - { -1 }, -}; - -void tcg_target_init(TCGContext *s) -{ - /* fail safe */ - if ((1 << CPU_TLB_ENTRY_BITS) != sizeof(CPUTLBEntry)) - tcg_abort(); - - tcg_regset_set32(tcg_target_available_regs[TCG_TYPE_I32], 0, 0xffff); - tcg_regset_set32(tcg_target_available_regs[TCG_TYPE_I64], 0, 0xffff); - tcg_regset_set32(tcg_target_call_clobber_regs, 0, - (1 << TCG_REG_RDI) | - (1 << TCG_REG_RSI) | - (1 << TCG_REG_RDX) | - (1 << TCG_REG_RCX) | - (1 << TCG_REG_R8) | - (1 << TCG_REG_R9) | - (1 << TCG_REG_RAX) | - (1 << TCG_REG_R10) | - (1 << TCG_REG_R11)); - - tcg_regset_clear(s->reserved_regs); - tcg_regset_set_reg(s->reserved_regs, TCG_REG_RSP); - - tcg_add_target_add_op_defs(x86_64_op_defs); -} diff --git a/qemu/qemu-git/tcg/x86_64/.svn/text-base/tcg-target.h.svn-base b/qemu/qemu-git/tcg/x86_64/.svn/text-base/tcg-target.h.svn-base deleted file mode 100644 index 3ca392f..0000000 --- a/qemu/qemu-git/tcg/x86_64/.svn/text-base/tcg-target.h.svn-base +++ /dev/null @@ -1,91 +0,0 @@ -/* - * Tiny Code Generator for QEMU - * - * Copyright (c) 2008 Fabrice Bellard - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - */ -#define TCG_TARGET_X86_64 1 - -#define TCG_TARGET_REG_BITS 64 -//#define TCG_TARGET_WORDS_BIGENDIAN - -#define TCG_TARGET_NB_REGS 16 - -enum { - TCG_REG_RAX = 0, - TCG_REG_RCX, - TCG_REG_RDX, - TCG_REG_RBX, - TCG_REG_RSP, - TCG_REG_RBP, - TCG_REG_RSI, - TCG_REG_RDI, - TCG_REG_R8, - TCG_REG_R9, - TCG_REG_R10, - TCG_REG_R11, - TCG_REG_R12, - TCG_REG_R13, - TCG_REG_R14, - TCG_REG_R15, -}; - -#define TCG_CT_CONST_S32 0x100 -#define TCG_CT_CONST_U32 0x200 - -/* used for function call generation */ -#define TCG_REG_CALL_STACK TCG_REG_RSP -#define TCG_TARGET_STACK_ALIGN 16 -#define TCG_TARGET_CALL_STACK_OFFSET 0 - -/* optional instructions */ -#define TCG_TARGET_HAS_bswap16_i32 -#define TCG_TARGET_HAS_bswap16_i64 -#define TCG_TARGET_HAS_bswap32_i32 -#define TCG_TARGET_HAS_bswap32_i64 -#define TCG_TARGET_HAS_bswap64_i64 -#define TCG_TARGET_HAS_neg_i32 -#define TCG_TARGET_HAS_neg_i64 -#define TCG_TARGET_HAS_not_i32 -#define TCG_TARGET_HAS_not_i64 -#define TCG_TARGET_HAS_ext8s_i32 -#define TCG_TARGET_HAS_ext16s_i32 -#define TCG_TARGET_HAS_ext8s_i64 -#define TCG_TARGET_HAS_ext16s_i64 -#define TCG_TARGET_HAS_ext32s_i64 -#define TCG_TARGET_HAS_ext8u_i32 -#define TCG_TARGET_HAS_ext16u_i32 -#define TCG_TARGET_HAS_ext8u_i64 -#define TCG_TARGET_HAS_ext16u_i64 -#define TCG_TARGET_HAS_ext32u_i64 - -#define TCG_TARGET_HAS_rot_i32 -#define TCG_TARGET_HAS_rot_i64 - -#define TCG_TARGET_HAS_GUEST_BASE - -/* Note: must be synced with dyngen-exec.h */ -#define TCG_AREG0 TCG_REG_R14 -#define TCG_AREG1 TCG_REG_R15 -#define TCG_AREG2 TCG_REG_R12 - -static inline void flush_icache_range(unsigned long start, unsigned long stop) -{ -} diff --git a/sim/.svn/all-wcprops b/sim/.svn/all-wcprops deleted file mode 100644 index e97d8f2..0000000 --- a/sim/.svn/all-wcprops +++ /dev/null @@ -1,11 +0,0 @@ -K 25 -svn:wc:ra_dav:version-url -V 28 -/p/x49gp/code/!svn/ver/1/sim -END -.cvsignore -K 25 -svn:wc:ra_dav:version-url -V 39 -/p/x49gp/code/!svn/ver/1/sim/.cvsignore -END diff --git a/sim/.svn/entries b/sim/.svn/entries deleted file mode 100644 index 87e27c3..0000000 --- a/sim/.svn/entries +++ /dev/null @@ -1,65 +0,0 @@ -10 - -dir -11 -http://svn.code.sf.net/p/x49gp/code/sim -http://svn.code.sf.net/p/x49gp/code - - - -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - -481df3bd-3408-496c-b7de-451e46197bb5 - -CVS -dir - -.cvsignore -file - - - - -2013-08-23T00:54:47.000000Z -488f0c41a36feb0e3c34a18494aefd3f -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -8 - diff --git a/sim/.svn/text-base/.cvsignore.svn-base b/sim/.svn/text-base/.cvsignore.svn-base deleted file mode 100644 index 4671378..0000000 --- a/sim/.svn/text-base/.cvsignore.svn-base +++ /dev/null @@ -1 +0,0 @@ -.depend diff --git a/sim/CVS/.svn/all-wcprops b/sim/CVS/.svn/all-wcprops deleted file mode 100644 index a7665a8..0000000 --- a/sim/CVS/.svn/all-wcprops +++ /dev/null @@ -1,23 +0,0 @@ -K 25 -svn:wc:ra_dav:version-url -V 32 -/p/x49gp/code/!svn/ver/1/sim/CVS -END -Repository -K 25 -svn:wc:ra_dav:version-url -V 43 -/p/x49gp/code/!svn/ver/1/sim/CVS/Repository -END -Root -K 25 -svn:wc:ra_dav:version-url -V 37 -/p/x49gp/code/!svn/ver/1/sim/CVS/Root -END -Entries -K 25 -svn:wc:ra_dav:version-url -V 40 -/p/x49gp/code/!svn/ver/1/sim/CVS/Entries -END diff --git a/sim/CVS/.svn/entries b/sim/CVS/.svn/entries deleted file mode 100644 index 4fa311f..0000000 --- a/sim/CVS/.svn/entries +++ /dev/null @@ -1,130 +0,0 @@ -10 - -dir -11 -http://svn.code.sf.net/p/x49gp/code/sim/CVS -http://svn.code.sf.net/p/x49gp/code - - - -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - -481df3bd-3408-496c-b7de-451e46197bb5 - -Repository -file - - - - -2013-08-23T00:54:47.000000Z -9f8e001171432a129c6bf43877c5f5a5 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -10 - -Root -file - - - - -2013-08-23T00:54:47.000000Z -f51b768066a9e7d88829b19678326fcd -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -60 - -Entries -file - - - - -2013-08-23T00:54:47.000000Z -1efa19e73f625258cecf55ab9aa867b5 -2008-12-11T16:48:39.837984Z -1 -antiocles - - - - - - - - - - - - - - - - - - - - - -45 - diff --git a/sim/CVS/.svn/text-base/Entries.svn-base b/sim/CVS/.svn/text-base/Entries.svn-base deleted file mode 100644 index abd9e8e..0000000 --- a/sim/CVS/.svn/text-base/Entries.svn-base +++ /dev/null @@ -1,2 +0,0 @@ -/.cvsignore/1.1/Thu Jun 8 05:41:42 2006// -D diff --git a/sim/CVS/.svn/text-base/Repository.svn-base b/sim/CVS/.svn/text-base/Repository.svn-base deleted file mode 100644 index 0374a59..0000000 --- a/sim/CVS/.svn/text-base/Repository.svn-base +++ /dev/null @@ -1 +0,0 @@ -x49gp/sim diff --git a/sim/CVS/.svn/text-base/Root.svn-base b/sim/CVS/.svn/text-base/Root.svn-base deleted file mode 100644 index 6f29e94..0000000 --- a/sim/CVS/.svn/text-base/Root.svn-base +++ /dev/null @@ -1 +0,0 @@ -:pserver:anonymous@x49gp.cvs.sourceforge.net:/cvsroot/x49gp