Rizin
unix-like reverse engineering framework and cli tools
opcode_31.c
Go to the documentation of this file.
1 // SPDX-FileCopyrightText: 2020 FXTi <zjxiang1998@gmail.com>
2 // SPDX-License-Identifier: LGPL-3.0-only
3 
4 #include "opcode.h"
5 
7  pyc_opcodes *ret = opcode_32();
8  if (!ret) {
9  return NULL;
10  }
11 
12  ret->version_sig = (void *(*)())opcode_31;
13 
14  // These are in Python 3.2 but not in Python 3.1
15  rm_op(.op_obj = ret->opcodes, .op_name = "DUP_TOP_TWO", .op_code = 5);
16  rm_op(.op_obj = ret->opcodes, .op_name = "DELETE_DEREF", .op_code = 138);
17  rm_op(.op_obj = ret->opcodes, .op_name = "SETUP_WITH", .op_code = 143);
18 
19  // These are in Python 3.1 but not Python 3.2
20  def_op(.op_obj = ret->opcodes, .op_name = "ROT_FOUR", .op_code = 5);
21  def_op(.op_obj = ret->opcodes, .op_name = "DUP_TOPX", .op_code = 99);
22 
23  // This op is in 3.2 but its opcode is a 144 instead
24  def_op(.op_obj = ret->opcodes, .op_name = "EXTENDED_ARG", .op_code = 143);
25 
27  add_arg_fmt(ret, "EXTENDED_ARG", format_extended_arg);
28  add_arg_fmt(ret, "MAKE_FUNCTION", format_MAKE_FUNCTION_arg_3x);
29 
30  return ret;
31 }
#define NULL
Definition: cris-opc.c:27
RZ_API void rz_list_purge(RZ_NONNULL RzList *list)
Empties the list without freeing the list pointer.
Definition: list.c:120
void add_arg_fmt(pyc_opcodes *ret, char *op_name, const char *(*formatter)(ut32 oparg))
Definition: opcode.c:234
pyc_opcodes * opcode_31(void)
Definition: opcode_31.c:6
pyc_opcodes * opcode_32(void)
Definition: opcode_32.c:6
const char * format_extended_arg(ut32 oparg)
Definition: opcode_arg_fmt.c:6
const char * format_MAKE_FUNCTION_arg_3x(ut32 oparg)
#define def_op(...)
Definition: opcode.h:127
#define rm_op(...)
Definition: opcode.h:175
char * op_name
Definition: opcode.h:38
void *(* version_sig)()
Definition: opcode.h:49
pyc_opcode_object * opcodes
Definition: opcode.h:51
RzList * opcode_arg_fmt
Definition: opcode.h:50