/* -*- mode: C; c-basic-offset: 3; -*- */ /*---------------------------------------------------------------*/ /*--- begin host_s390_disasm.h ---*/ /*---------------------------------------------------------------*/ /* This file is part of Valgrind, a dynamic binary instrumentation framework. Copyright IBM Corp. 2010-2011 This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. The GNU General Public License is contained in the file COPYING. */ #ifndef __VEX_HOST_S390_DISASM_H #define __VEX_HOST_S390_DISASM_H #include "libvex_basictypes.h" /* Macros to encode a command for s390_disasm. */ #undef P #define P(a) (S390_ARG_##a) #undef ENC1 #define ENC1(a) ((P(DONE) << 4) | P(a)) #undef ENC2 #define ENC2(a,b) ((P(DONE) << 8) | (P(b) << 4) | P(a)) #undef ENC3 #define ENC3(a,b,c) ((P(DONE) << 12) | (P(c) << 8) | (P(b) << 4) | P(a)) #undef ENC4 #define ENC4(a,b,c,d) ((P(DONE) << 16) | (P(d) << 12) | (P(c) << 8) | \ (P(b) << 4) | P(a)) #undef ENC5 #define ENC5(a,b,c,d,e) ((P(DONE) << 20) | (P(e) << 16) | (P(d) << 12) | \ (P(c) << 8) | (P(b) << 4) | P(a)) #undef ENC6 #define ENC6(a,b,c,d,e,f) ((P(DONE) << 24) | (P(f) << 20) | (P(e) << 16) | \ (P(d) << 12) | (P(c) << 8) | (P(b) << 4) | P(a)) /* The different kinds of operands in an asm insn */ enum { S390_ARG_DONE = 0, S390_ARG_GPR = 1, S390_ARG_FPR = 2, S390_ARG_AR = 3, S390_ARG_INT = 4, S390_ARG_UINT = 5, S390_ARG_PCREL = 6, S390_ARG_SDXB = 7, S390_ARG_UDXB = 8, S390_ARG_UDLB = 9, S390_ARG_CABM = 10, S390_ARG_MNM = 11, S390_ARG_XMNM = 12 }; /* The different kinds of extended mnemonics */ enum { S390_XMNM_CAB = 0, S390_XMNM_BCR = 1, S390_XMNM_BC = 2, S390_XMNM_BRC = 3, S390_XMNM_BRCL = 4, S390_XMNM_LOCR = 5, S390_XMNM_LOCGR = 6, S390_XMNM_LOC = 7, S390_XMNM_LOCG = 8, S390_XMNM_STOC = 9, S390_XMNM_STOCG = 10 }; void s390_disasm(UInt command, ...); /*---------------------------------------------------------------*/ /*--- end host_s390_disasm.h ---*/ /*---------------------------------------------------------------*/ #endif /* __VEX_HOST_S390_DISASM_H */