This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
1f6498a86d9dab28ebdac6bfc88a21a3b39b0794
[perl5.git] / ext / B / B / Asmdata.pm
1 #
2 #      Copyright (c) 1996-1999 Malcolm Beattie
3 #
4 #      You may distribute under the terms of either the GNU General Public
5 #      License or the Artistic License, as specified in the README file.
6 #
7 #
8 #
9 # This file is autogenerated from bytecode.pl. Changes made here will be lost.
10 #
11 package B::Asmdata;
12
13 our $VERSION = '1.00';
14
15 use Exporter;
16 @ISA = qw(Exporter);
17 @EXPORT_OK = qw(%insn_data @insn_name @optype @specialsv_name);
18 our(%insn_data, @insn_name, @optype, @specialsv_name);
19
20 @optype = qw(OP UNOP BINOP LOGOP LISTOP PMOP SVOP PADOP PVOP LOOP COP);
21 @specialsv_name = qw(Nullsv &PL_sv_undef &PL_sv_yes &PL_sv_no pWARN_ALL pWARN_NONE);
22
23 # XXX insn_data is initialised this way because with a large
24 # %insn_data = (foo => [...], bar => [...], ...) initialiser
25 # I get a hard-to-track-down stack underflow and segfault.
26 $insn_data{comment} = [35, \&PUT_comment_t, "GET_comment_t"];
27 $insn_data{nop} = [10, \&PUT_none, "GET_none"];
28 $insn_data{ret} = [0, \&PUT_none, "GET_none"];
29 $insn_data{ldsv} = [1, \&PUT_svindex, "GET_svindex"];
30 $insn_data{ldop} = [2, \&PUT_opindex, "GET_opindex"];
31 $insn_data{stsv} = [3, \&PUT_U32, "GET_U32"];
32 $insn_data{stop} = [4, \&PUT_U32, "GET_U32"];
33 $insn_data{stpv} = [5, \&PUT_U32, "GET_U32"];
34 $insn_data{ldspecsv} = [6, \&PUT_U8, "GET_U8"];
35 $insn_data{newsv} = [7, \&PUT_U8, "GET_U8"];
36 $insn_data{newop} = [8, \&PUT_U8, "GET_U8"];
37 $insn_data{newopn} = [9, \&PUT_U8, "GET_U8"];
38 $insn_data{newpv} = [11, \&PUT_PV, "GET_PV"];
39 $insn_data{pv_cur} = [12, \&PUT_U32, "GET_U32"];
40 $insn_data{pv_free} = [13, \&PUT_none, "GET_none"];
41 $insn_data{sv_upgrade} = [14, \&PUT_U8, "GET_U8"];
42 $insn_data{sv_refcnt} = [15, \&PUT_U32, "GET_U32"];
43 $insn_data{sv_refcnt_add} = [16, \&PUT_I32, "GET_I32"];
44 $insn_data{sv_flags} = [17, \&PUT_U32, "GET_U32"];
45 $insn_data{xrv} = [18, \&PUT_svindex, "GET_svindex"];
46 $insn_data{xpv} = [19, \&PUT_none, "GET_none"];
47 $insn_data{xiv32} = [20, \&PUT_I32, "GET_I32"];
48 $insn_data{xiv64} = [21, \&PUT_IV64, "GET_IV64"];
49 $insn_data{xnv} = [22, \&PUT_NV, "GET_NV"];
50 $insn_data{xlv_targoff} = [23, \&PUT_U32, "GET_U32"];
51 $insn_data{xlv_targlen} = [24, \&PUT_U32, "GET_U32"];
52 $insn_data{xlv_targ} = [25, \&PUT_svindex, "GET_svindex"];
53 $insn_data{xlv_type} = [26, \&PUT_U8, "GET_U8"];
54 $insn_data{xbm_useful} = [27, \&PUT_I32, "GET_I32"];
55 $insn_data{xbm_previous} = [28, \&PUT_U16, "GET_U16"];
56 $insn_data{xbm_rare} = [29, \&PUT_U8, "GET_U8"];
57 $insn_data{xfm_lines} = [30, \&PUT_IV, "GET_IV"];
58 $insn_data{xio_lines} = [31, \&PUT_IV, "GET_IV"];
59 $insn_data{xio_page} = [32, \&PUT_IV, "GET_IV"];
60 $insn_data{xio_page_len} = [33, \&PUT_IV, "GET_IV"];
61 $insn_data{xio_lines_left} = [34, \&PUT_IV, "GET_IV"];
62 $insn_data{xio_top_name} = [36, \&PUT_pvcontents, "GET_pvcontents"];
63 $insn_data{xio_top_gv} = [37, \&PUT_svindex, "GET_svindex"];
64 $insn_data{xio_fmt_name} = [38, \&PUT_pvcontents, "GET_pvcontents"];
65 $insn_data{xio_fmt_gv} = [39, \&PUT_svindex, "GET_svindex"];
66 $insn_data{xio_bottom_name} = [40, \&PUT_pvcontents, "GET_pvcontents"];
67 $insn_data{xio_bottom_gv} = [41, \&PUT_svindex, "GET_svindex"];
68 $insn_data{xio_subprocess} = [42, \&PUT_U16, "GET_U16"];
69 $insn_data{xio_type} = [43, \&PUT_U8, "GET_U8"];
70 $insn_data{xio_flags} = [44, \&PUT_U8, "GET_U8"];
71 $insn_data{xcv_stash} = [45, \&PUT_svindex, "GET_svindex"];
72 $insn_data{xcv_start} = [46, \&PUT_opindex, "GET_opindex"];
73 $insn_data{xcv_root} = [47, \&PUT_opindex, "GET_opindex"];
74 $insn_data{xcv_gv} = [48, \&PUT_svindex, "GET_svindex"];
75 $insn_data{xcv_file} = [49, \&PUT_pvindex, "GET_pvindex"];
76 $insn_data{xcv_depth} = [50, \&PUT_I32, "GET_I32"];
77 $insn_data{xcv_padlist} = [51, \&PUT_svindex, "GET_svindex"];
78 $insn_data{xcv_outside} = [52, \&PUT_svindex, "GET_svindex"];
79 $insn_data{xcv_outside_seq} = [53, \&PUT_U32, "GET_U32"];
80 $insn_data{xcv_flags} = [54, \&PUT_U16, "GET_U16"];
81 $insn_data{av_extend} = [55, \&PUT_I32, "GET_I32"];
82 $insn_data{av_push} = [56, \&PUT_svindex, "GET_svindex"];
83 $insn_data{xav_fill} = [57, \&PUT_I32, "GET_I32"];
84 $insn_data{xav_max} = [58, \&PUT_I32, "GET_I32"];
85 $insn_data{xav_flags} = [59, \&PUT_U8, "GET_U8"];
86 $insn_data{xhv_riter} = [60, \&PUT_I32, "GET_I32"];
87 $insn_data{xhv_name} = [61, \&PUT_pvcontents, "GET_pvcontents"];
88 $insn_data{hv_store} = [62, \&PUT_svindex, "GET_svindex"];
89 $insn_data{sv_magic} = [63, \&PUT_U8, "GET_U8"];
90 $insn_data{mg_obj} = [64, \&PUT_svindex, "GET_svindex"];
91 $insn_data{mg_private} = [65, \&PUT_U16, "GET_U16"];
92 $insn_data{mg_flags} = [66, \&PUT_U8, "GET_U8"];
93 $insn_data{mg_pv} = [67, \&PUT_pvcontents, "GET_pvcontents"];
94 $insn_data{xmg_stash} = [68, \&PUT_svindex, "GET_svindex"];
95 $insn_data{gv_fetchpv} = [69, \&PUT_strconst, "GET_strconst"];
96 $insn_data{gv_stashpv} = [70, \&PUT_strconst, "GET_strconst"];
97 $insn_data{gp_sv} = [71, \&PUT_svindex, "GET_svindex"];
98 $insn_data{gp_refcnt} = [72, \&PUT_U32, "GET_U32"];
99 $insn_data{gp_refcnt_add} = [73, \&PUT_I32, "GET_I32"];
100 $insn_data{gp_av} = [74, \&PUT_svindex, "GET_svindex"];
101 $insn_data{gp_hv} = [75, \&PUT_svindex, "GET_svindex"];
102 $insn_data{gp_cv} = [76, \&PUT_svindex, "GET_svindex"];
103 $insn_data{gp_file} = [77, \&PUT_pvindex, "GET_pvindex"];
104 $insn_data{gp_io} = [78, \&PUT_svindex, "GET_svindex"];
105 $insn_data{gp_form} = [79, \&PUT_svindex, "GET_svindex"];
106 $insn_data{gp_cvgen} = [80, \&PUT_U32, "GET_U32"];
107 $insn_data{gp_line} = [81, \&PUT_U16, "GET_U16"];
108 $insn_data{gp_share} = [82, \&PUT_svindex, "GET_svindex"];
109 $insn_data{xgv_flags} = [83, \&PUT_U8, "GET_U8"];
110 $insn_data{op_next} = [84, \&PUT_opindex, "GET_opindex"];
111 $insn_data{op_sibling} = [85, \&PUT_opindex, "GET_opindex"];
112 $insn_data{op_ppaddr} = [86, \&PUT_strconst, "GET_strconst"];
113 $insn_data{op_targ} = [87, \&PUT_U32, "GET_U32"];
114 $insn_data{op_type} = [88, \&PUT_U16, "GET_U16"];
115 $insn_data{op_seq} = [89, \&PUT_U16, "GET_U16"];
116 $insn_data{op_flags} = [90, \&PUT_U8, "GET_U8"];
117 $insn_data{op_private} = [91, \&PUT_U8, "GET_U8"];
118 $insn_data{op_first} = [92, \&PUT_opindex, "GET_opindex"];
119 $insn_data{op_last} = [93, \&PUT_opindex, "GET_opindex"];
120 $insn_data{op_other} = [94, \&PUT_opindex, "GET_opindex"];
121 $insn_data{op_pmreplroot} = [95, \&PUT_opindex, "GET_opindex"];
122 $insn_data{op_pmreplrootgv} = [96, \&PUT_svindex, "GET_svindex"];
123 $insn_data{op_pmreplstart} = [97, \&PUT_opindex, "GET_opindex"];
124 $insn_data{op_pmnext} = [98, \&PUT_opindex, "GET_opindex"];
125 $insn_data{pregcomp} = [99, \&PUT_pvcontents, "GET_pvcontents"];
126 $insn_data{op_pmflags} = [100, \&PUT_U16, "GET_U16"];
127 $insn_data{op_pmpermflags} = [101, \&PUT_U16, "GET_U16"];
128 $insn_data{op_sv} = [102, \&PUT_svindex, "GET_svindex"];
129 $insn_data{op_padix} = [103, \&PUT_U32, "GET_U32"];
130 $insn_data{op_pv} = [104, \&PUT_pvcontents, "GET_pvcontents"];
131 $insn_data{op_pv_tr} = [105, \&PUT_op_tr_array, "GET_op_tr_array"];
132 $insn_data{op_redoop} = [106, \&PUT_opindex, "GET_opindex"];
133 $insn_data{op_nextop} = [107, \&PUT_opindex, "GET_opindex"];
134 $insn_data{op_lastop} = [108, \&PUT_opindex, "GET_opindex"];
135 $insn_data{cop_label} = [109, \&PUT_pvindex, "GET_pvindex"];
136 $insn_data{cop_stashpv} = [110, \&PUT_pvindex, "GET_pvindex"];
137 $insn_data{cop_file} = [111, \&PUT_pvindex, "GET_pvindex"];
138 $insn_data{cop_seq} = [112, \&PUT_U32, "GET_U32"];
139 $insn_data{cop_arybase} = [113, \&PUT_I32, "GET_I32"];
140 $insn_data{cop_line} = [114, \&PUT_U16, "GET_U16"];
141 $insn_data{cop_warnings} = [115, \&PUT_svindex, "GET_svindex"];
142 $insn_data{main_start} = [116, \&PUT_opindex, "GET_opindex"];
143 $insn_data{main_root} = [117, \&PUT_opindex, "GET_opindex"];
144 $insn_data{curpad} = [118, \&PUT_svindex, "GET_svindex"];
145 $insn_data{push_begin} = [119, \&PUT_svindex, "GET_svindex"];
146 $insn_data{push_init} = [120, \&PUT_svindex, "GET_svindex"];
147 $insn_data{push_end} = [121, \&PUT_svindex, "GET_svindex"];
148
149 my ($insn_name, $insn_data);
150 while (($insn_name, $insn_data) = each %insn_data) {
151     $insn_name[$insn_data->[0]] = $insn_name;
152 }
153 # Fill in any gaps
154 @insn_name = map($_ || "unused", @insn_name);
155
156 1;
157
158 __END__
159
160 =head1 NAME
161
162 B::Asmdata - Autogenerated data about Perl ops, used to generate bytecode
163
164 =head1 SYNOPSIS
165
166         use B::Asmdata qw(%insn_data @insn_name @optype @specialsv_name);
167
168 =head1 DESCRIPTION
169
170 Provides information about Perl ops in order to generate bytecode via
171 a bunch of exported variables.  Its mostly used by B::Assembler and
172 B::Disassembler.
173
174 =over 4
175
176 =item %insn_data
177
178   my($bytecode_num, $put_sub, $get_meth) = @$insn_data{$op_name};
179
180 For a given $op_name (for example, 'cop_label', 'sv_flags', etc...) 
181 you get an array ref containing the bytecode number of the op, a
182 reference to the subroutine used to 'PUT', and the name of the method
183 used to 'GET'.
184
185 =for _private
186 Add more detail about what $put_sub and $get_meth are and how to use them.
187
188 =item @insn_name
189
190   my $op_name = $insn_name[$bytecode_num];
191
192 A simple mapping of the bytecode number to the name of the op.
193 Suitable for using with %insn_data like so:
194
195   my $op_info = $insn_data{$insn_name[$bytecode_num]};
196
197 =item @optype
198
199   my $op_type = $optype[$op_type_num];
200
201 A simple mapping of the op type number to its type (like 'COP' or 'BINOP').
202
203 =item @specialsv_name
204
205   my $sv_name = $specialsv_name[$sv_index];
206
207 Certain SV types are considered 'special'.  They're represented by
208 B::SPECIAL and are refered to by a number from the specialsv_list.
209 This array maps that number back to the name of the SV (like 'Nullsv'
210 or '&PL_sv_undef').
211
212 =back
213
214 =head1 AUTHOR
215
216 Malcolm Beattie, C<mbeattie@sable.ox.ac.uk>
217
218 =cut