123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322 |
- # -#- buffer-read-only: t -#-
- #
- # Copyright (c) 1996-1999 Malcolm Beattie
- # Copyright (c) 2008,2009,2010,2011 Reini Urban
- #
- # You may distribute under the terms of either the GNU General Public
- # License or the Artistic License, as specified in the README file.
- #
- #
- #
- # This file is autogenerated from bytecode.pl. Changes made here will be lost.
- # It is specific for Perl 5.012003-nt only.
- #
- package B::Asm5_012003;
- our $VERSION = '1.03';
- use Exporter;
- @ISA = qw(Exporter);
- @EXPORT_OK = qw(%insn_data @insn_name @optype @specialsv_name);
- our(%insn_data, @insn_name);
- use B qw(@optype @specialsv_name);
- # XXX insn_data is initialised this way because with a large
- # %insn_data = (foo => [...], bar => [...], ...) initialiser
- # I get a hard-to-track-down stack underflow and segfault.
- $insn_data{comment} = [35, \&PUT_comment_t, "GET_comment_t"];
- $insn_data{nop} = [10, \&PUT_none, "GET_none"];
- $insn_data{ret} = [0, \&PUT_none, "GET_none"];
- $insn_data{ldsv} = [1, \&PUT_svindex, "GET_svindex"];
- $insn_data{ldop} = [2, \&PUT_opindex, "GET_opindex"];
- $insn_data{stsv} = [3, \&PUT_U32, "GET_U32"];
- $insn_data{stop} = [4, \&PUT_U32, "GET_U32"];
- $insn_data{stpv} = [5, \&PUT_U32, "GET_U32"];
- $insn_data{ldspecsv} = [6, \&PUT_U8, "GET_U8"];
- $insn_data{ldspecsvx} = [7, \&PUT_U8, "GET_U8"];
- $insn_data{newsv} = [8, \&PUT_U8, "GET_U8"];
- $insn_data{newsvx} = [9, \&PUT_U32, "GET_U32"];
- $insn_data{newop} = [11, \&PUT_U8, "GET_U8"];
- $insn_data{newopx} = [12, \&PUT_U16, "GET_U16"];
- $insn_data{newopn} = [13, \&PUT_U8, "GET_U8"];
- $insn_data{newpv} = [14, \&PUT_PV, "GET_PV"];
- $insn_data{pv_cur} = [15, \&PUT_PADOFFSET, "GET_PADOFFSET"];
- $insn_data{pv_free} = [16, \&PUT_none, "GET_none"];
- $insn_data{sv_upgrade} = [17, \&PUT_U8, "GET_U8"];
- $insn_data{sv_refcnt} = [18, \&PUT_U32, "GET_U32"];
- $insn_data{sv_refcnt_add} = [19, \&PUT_I32, "GET_I32"];
- $insn_data{sv_flags} = [20, \&PUT_U32, "GET_U32"];
- $insn_data{xrv} = [21, \&PUT_svindex, "GET_svindex"];
- $insn_data{xpv} = [22, \&PUT_none, "GET_none"];
- $insn_data{xpv_cur} = [23, \&PUT_PADOFFSET, "GET_PADOFFSET"];
- $insn_data{xpv_len} = [24, \&PUT_PADOFFSET, "GET_PADOFFSET"];
- $insn_data{xiv} = [25, \&PUT_IV, "GET_IV"];
- $insn_data{xnv} = [26, \&PUT_NV, "GET_NV"];
- $insn_data{xlv_targoff} = [27, \&PUT_PADOFFSET, "GET_PADOFFSET"];
- $insn_data{xlv_targlen} = [28, \&PUT_PADOFFSET, "GET_PADOFFSET"];
- $insn_data{xlv_targ} = [29, \&PUT_svindex, "GET_svindex"];
- $insn_data{xlv_type} = [30, \&PUT_U8, "GET_U8"];
- $insn_data{xbm_useful} = [31, \&PUT_I32, "GET_I32"];
- $insn_data{xbm_previous} = [32, \&PUT_U16, "GET_U16"];
- $insn_data{xbm_rare} = [33, \&PUT_U8, "GET_U8"];
- $insn_data{xfm_lines} = [34, \&PUT_IV, "GET_IV"];
- $insn_data{xio_lines} = [36, \&PUT_IV, "GET_IV"];
- $insn_data{xio_page} = [37, \&PUT_IV, "GET_IV"];
- $insn_data{xio_page_len} = [38, \&PUT_IV, "GET_IV"];
- $insn_data{xio_lines_left} = [39, \&PUT_IV, "GET_IV"];
- $insn_data{xio_top_name} = [40, \&PUT_pvindex, "GET_pvindex"];
- $insn_data{xio_top_gv} = [41, \&PUT_svindex, "GET_svindex"];
- $insn_data{xio_fmt_name} = [42, \&PUT_pvindex, "GET_pvindex"];
- $insn_data{xio_fmt_gv} = [43, \&PUT_svindex, "GET_svindex"];
- $insn_data{xio_bottom_name} = [44, \&PUT_pvindex, "GET_pvindex"];
- $insn_data{xio_bottom_gv} = [45, \&PUT_svindex, "GET_svindex"];
- $insn_data{xio_subprocess} = [46, 0, "GET_U16"];
- $insn_data{xio_type} = [47, \&PUT_U8, "GET_U8"];
- $insn_data{xio_flags} = [48, \&PUT_U8, "GET_U8"];
- $insn_data{xcv_xsubany} = [49, \&PUT_svindex, "GET_svindex"];
- $insn_data{xcv_stash} = [50, \&PUT_svindex, "GET_svindex"];
- $insn_data{xcv_start} = [51, \&PUT_opindex, "GET_opindex"];
- $insn_data{xcv_root} = [52, \&PUT_opindex, "GET_opindex"];
- $insn_data{xcv_gv} = [53, \&PUT_svindex, "GET_svindex"];
- $insn_data{xcv_file} = [54, \&PUT_pvindex, "GET_pvindex"];
- $insn_data{xcv_depth} = [55, \&PUT_long, "GET_long"];
- $insn_data{xcv_padlist} = [56, \&PUT_svindex, "GET_svindex"];
- $insn_data{xcv_outside} = [57, \&PUT_svindex, "GET_svindex"];
- $insn_data{xcv_outside_seq} = [58, \&PUT_U32, "GET_U32"];
- $insn_data{xcv_flags} = [59, \&PUT_U16, "GET_U16"];
- $insn_data{av_extend} = [60, \&PUT_PADOFFSET, "GET_PADOFFSET"];
- $insn_data{av_pushx} = [61, \&PUT_svindex, "GET_svindex"];
- $insn_data{av_push} = [62, 0, "GET_svindex"];
- $insn_data{xav_fill} = [63, 0, "GET_PADOFFSET"];
- $insn_data{xav_max} = [64, 0, "GET_PADOFFSET"];
- $insn_data{xhv_riter} = [66, 0, "GET_I32"];
- $insn_data{xhv_name} = [67, \&PUT_pvindex, "GET_pvindex"];
- $insn_data{xhv_pmroot} = [68, 0, "GET_opindex"];
- $insn_data{hv_store} = [69, \&PUT_svindex, "GET_svindex"];
- $insn_data{sv_magic} = [70, \&PUT_U8, "GET_U8"];
- $insn_data{mg_obj} = [71, \&PUT_svindex, "GET_svindex"];
- $insn_data{mg_private} = [72, \&PUT_U16, "GET_U16"];
- $insn_data{mg_flags} = [73, \&PUT_U8, "GET_U8"];
- $insn_data{mg_name} = [74, \&PUT_pvcontents, "GET_pvcontents"];
- $insn_data{mg_namex} = [75, \&PUT_svindex, "GET_svindex"];
- $insn_data{xmg_stash} = [76, \&PUT_svindex, "GET_svindex"];
- $insn_data{gv_fetchpv} = [77, \&PUT_strconst, "GET_strconst"];
- $insn_data{gv_fetchpvx} = [78, \&PUT_strconst, "GET_strconst"];
- $insn_data{gv_stashpv} = [79, \&PUT_strconst, "GET_strconst"];
- $insn_data{gv_stashpvx} = [80, \&PUT_strconst, "GET_strconst"];
- $insn_data{gp_sv} = [81, \&PUT_svindex, "GET_svindex"];
- $insn_data{gp_refcnt} = [82, \&PUT_U32, "GET_U32"];
- $insn_data{gp_refcnt_add} = [83, \&PUT_I32, "GET_I32"];
- $insn_data{gp_av} = [84, \&PUT_svindex, "GET_svindex"];
- $insn_data{gp_hv} = [85, \&PUT_svindex, "GET_svindex"];
- $insn_data{gp_cv} = [86, \&PUT_svindex, "GET_svindex"];
- $insn_data{gp_file} = [87, \&PUT_pvindex, "GET_pvindex"];
- $insn_data{gp_io} = [88, \&PUT_svindex, "GET_svindex"];
- $insn_data{gp_form} = [89, \&PUT_svindex, "GET_svindex"];
- $insn_data{gp_cvgen} = [90, \&PUT_U32, "GET_U32"];
- $insn_data{gp_line} = [91, \&PUT_U32, "GET_U32"];
- $insn_data{gp_share} = [92, \&PUT_svindex, "GET_svindex"];
- $insn_data{xgv_flags} = [93, \&PUT_U8, "GET_U8"];
- $insn_data{op_next} = [94, \&PUT_opindex, "GET_opindex"];
- $insn_data{op_sibling} = [95, \&PUT_opindex, "GET_opindex"];
- $insn_data{op_ppaddr} = [96, \&PUT_strconst, "GET_strconst"];
- $insn_data{op_targ} = [97, \&PUT_PADOFFSET, "GET_PADOFFSET"];
- $insn_data{op_type} = [98, \&PUT_U16, "GET_U16"];
- $insn_data{op_opt} = [99, \&PUT_U8, "GET_U8"];
- $insn_data{op_flags} = [100, \&PUT_U8, "GET_U8"];
- $insn_data{op_private} = [101, \&PUT_U8, "GET_U8"];
- $insn_data{op_first} = [102, \&PUT_opindex, "GET_opindex"];
- $insn_data{op_last} = [103, \&PUT_opindex, "GET_opindex"];
- $insn_data{op_other} = [104, \&PUT_opindex, "GET_opindex"];
- $insn_data{op_pmreplroot} = [105, \&PUT_opindex, "GET_opindex"];
- $insn_data{op_pmreplstart} = [106, \&PUT_opindex, "GET_opindex"];
- $insn_data{op_pmstashpv} = [108, 0, "GET_pvindex"];
- $insn_data{op_pmstash} = [110, \&PUT_svindex, "GET_svindex"];
- $insn_data{op_pmreplrootgv} = [111, \&PUT_svindex, "GET_svindex"];
- $insn_data{pregcomp} = [112, \&PUT_pvcontents, "GET_pvcontents"];
- $insn_data{op_pmflags} = [113, \&PUT_pmflags, "GET_pmflags"];
- $insn_data{op_pmpermflags} = [114, 0, "GET_U16"];
- $insn_data{op_pmdynflags} = [115, 0, "GET_U8"];
- $insn_data{op_sv} = [116, \&PUT_svindex, "GET_svindex"];
- $insn_data{op_padix} = [117, \&PUT_PADOFFSET, "GET_PADOFFSET"];
- $insn_data{op_pv} = [118, \&PUT_pvcontents, "GET_pvcontents"];
- $insn_data{op_pv_tr} = [119, \&PUT_op_tr_array, "GET_op_tr_array"];
- $insn_data{op_redoop} = [120, \&PUT_opindex, "GET_opindex"];
- $insn_data{op_nextop} = [121, \&PUT_opindex, "GET_opindex"];
- $insn_data{op_lastop} = [122, \&PUT_opindex, "GET_opindex"];
- $insn_data{cop_label} = [123, \&PUT_pvindex, "GET_pvindex"];
- $insn_data{cop_stashpv} = [124, 0, "GET_pvindex"];
- $insn_data{cop_file} = [125, 0, "GET_pvindex"];
- $insn_data{cop_stash} = [126, \&PUT_svindex, "GET_svindex"];
- $insn_data{cop_filegv} = [127, \&PUT_svindex, "GET_svindex"];
- $insn_data{cop_seq} = [128, \&PUT_U32, "GET_U32"];
- $insn_data{cop_arybase} = [129, 0, "GET_I32"];
- $insn_data{cop_line} = [130, \&PUT_U32, "GET_U32"];
- $insn_data{cop_io} = [131, 0, "GET_svindex"];
- $insn_data{cop_warnings} = [132, \&PUT_svindex, "GET_svindex"];
- $insn_data{main_start} = [133, \&PUT_opindex, "GET_opindex"];
- $insn_data{main_root} = [134, \&PUT_opindex, "GET_opindex"];
- $insn_data{main_cv} = [135, \&PUT_svindex, "GET_svindex"];
- $insn_data{curpad} = [136, \&PUT_svindex, "GET_svindex"];
- $insn_data{push_begin} = [137, \&PUT_svindex, "GET_svindex"];
- $insn_data{push_init} = [138, \&PUT_svindex, "GET_svindex"];
- $insn_data{push_end} = [139, \&PUT_svindex, "GET_svindex"];
- $insn_data{curstash} = [140, \&PUT_svindex, "GET_svindex"];
- $insn_data{defstash} = [141, \&PUT_svindex, "GET_svindex"];
- $insn_data{data} = [142, \&PUT_U8, "GET_U8"];
- $insn_data{incav} = [143, \&PUT_svindex, "GET_svindex"];
- $insn_data{load_glob} = [144, \&PUT_svindex, "GET_svindex"];
- $insn_data{regex_padav} = [145, 0, "GET_svindex"];
- $insn_data{dowarn} = [146, \&PUT_U8, "GET_U8"];
- $insn_data{comppad_name} = [147, \&PUT_svindex, "GET_svindex"];
- $insn_data{xgv_stash} = [148, \&PUT_svindex, "GET_svindex"];
- $insn_data{signal} = [149, \&PUT_strconst, "GET_strconst"];
- $insn_data{formfeed} = [150, \&PUT_svindex, "GET_svindex"];
- $insn_data{op_latefree} = [151, \&PUT_U8, "GET_U8"];
- $insn_data{op_latefreed} = [152, \&PUT_U8, "GET_U8"];
- $insn_data{op_attached} = [153, \&PUT_U8, "GET_U8"];
- $insn_data{op_reflags} = [154, \&PUT_U32, "GET_U32"];
- $insn_data{cop_seq_low} = [155, \&PUT_U32, "GET_U32"];
- $insn_data{cop_seq_high} = [156, \&PUT_U32, "GET_U32"];
- $insn_data{gv_fetchpvn_flags} = [157, \&PUT_U32, "GET_U32"];
- my ($insn_name, $insn_data);
- while (($insn_name, $insn_data) = each %insn_data) {
- $insn_name[$insn_data->[0]] = $insn_name;
- }
- # Fill in any gaps
- @insn_name = map($_ || "unused", @insn_name);
- 1;
- __END__
- =head1 NAME
- B::Asmdata - Autogenerated data about Perl ops, used to generate bytecode
- =head1 SYNOPSIS
- use B::Asmdata qw(%insn_data @insn_name @optype @specialsv_name);
- =head1 DESCRIPTION
- Provides information about Perl ops in order to generate bytecode via
- a bunch of exported variables. Its mostly used by B::Assembler and
- B::Disassembler.
- =over 4
- =item %insn_data
- my($bytecode_num, $put_sub, $get_meth) = @$insn_data{$op_name};
- For a given $op_name (for example, 'cop_label', 'sv_flags', etc...)
- you get an array ref containing the bytecode number of the op, a
- reference to the subroutine used to 'PUT' the op argument to the bytecode stream,
- and the name of the method used to 'GET' op argument from the bytecode stream.
- Most ops require one arg, in fact all ops without the PUT/GET_none methods,
- and the GET and PUT methods are used to en-/decode the arg to binary bytecode.
- The names are constructed from the GET/PUT prefix and the argument type,
- such as U8, U16, U32, svindex, opindex, pvindex, ...
- The PUT method is used in the L<B::Bytecode> compiler within L<B::Assembler>,
- the GET method just for the L<B::Disassembler>.
- The GET method is not used by the binary L<ByteLoader> module.
- A full C<insn> table with version, opcode, name, lvalue, argtype and flags
- is located as DATA in F<bytecode.pl>.
- An empty PUT method, the number 0, denotes an unsupported bytecode for this perl.
- It is there to support disassembling older perl bytecode. This was added with 1.02_02.
- =item @insn_name
- my $op_name = $insn_name[$bytecode_num];
- A simple mapping of the bytecode number to the name of the op.
- Suitable for using with %insn_data like so:
- my $op_info = $insn_data{$insn_name[$bytecode_num]};
- =item @optype
- my $op_type = $optype[$op_type_num];
- A simple mapping of the op type number to its type (like 'COP' or 'BINOP').
- Since Perl version 5.10 defined in L<B>.
- =item @specialsv_name
- my $sv_name = $specialsv_name[$sv_index];
- Certain SV types are considered 'special'. They're represented by
- B::SPECIAL and are referred to by a number from the specialsv_list.
- This array maps that number back to the name of the SV (like 'Nullsv'
- or '&PL_sv_undef').
- Since Perl version 5.10 defined in L<B>.
- =back
- =head1 PORTABILITY
- All bytecode values are already portable.
- Cross-platform portability is implemented, cross-version not yet.
- Cross-version portability will be very limited, cross-platform only
- for the same threading model.
- =head2 CROSS-PLATFORM PORTABILITY
- For different endian-ness there are ByteLoader converters in effect.
- Header entry: byteorder.
- 64int - 64all - 32int is portable. Header entry: ivsize
- ITHREADS are unportable; header entry: archflag - bitflag 1.
- MULTIPLICITY is also unportable; header entry: archflag - bitflag 2
- TODO For cross-version portability we will try to translate older
- bytecode ops to the current perl op via L<ByteLoader::Translate>.
- Asmdata already contains the old ops, all with the PUT method 0.
- Header entry: perlversion
- =head2 CROSS-VERSION PORTABILITY (TODO - HARD)
- Bytecode ops:
- We can only reliably load bytecode from previous versions and promise
- that from 5.10.0 on future versions will only add new op numbers at
- the end, but will never replace old opcodes with incompatible arguments.
- Unsupported insn's are supported by disassemble, and if C<force> in the
- ByteLoader is set, it is tried to load/set them also, with probably fatal
- consequences.
- On the first unknown bytecode op from a future version - added to the end
- - we will die.
- L<ByteLoader::BcVersions> contains logic to translate previous errors
- from this bytecode policy. E.g. 5.8 violated the 5.6 bytecode order policy
- and began to juggle it around (similar to parrot), in detail removed
- various bytecodes, like ldspecsvx:7, xpv_cur, xpv_len, xiv64:26.
- So in theory it would have been possible to load 5.6 into 5.8 bytecode
- as the underlying perl pp_code ops didn't change that much, but it is risky.
- We have unused tables of all bytecode ops for all version-specific changes
- to the bytecode table. This only changed with
- the ByteLoader version, ithreads and major Perl versions.
- Also special replacements in the byteloader for all the unsupported
- ops, like xiv64, cop_arybase.
- =head1 AUTHOR
- Malcolm Beattie C<MICB at cpan.org> I<(retired)>,
- Reini Urban added the version logic, support >= 5.10, portability.
- =cut
- # ex: set ro:
|