2018-08-14 04:25:22 +00:00
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
< html >
< head >
< meta http-equiv = "content-type" content = "text/html; charset=UTF-8" >
2019-12-09 09:32:48 +00:00
< title > Mu - 033check_operands.cc< / title >
2019-07-14 16:42:36 +00:00
< meta name = "Generator" content = "Vim/8.1" >
< meta name = "plugin-version" content = "vim8.1_v1" >
2018-08-14 04:25:22 +00:00
< meta name = "syntax" content = "cpp" >
< meta name = "settings" content = "number_lines,use_css,pre_wrap,no_foldcolumn,expand_tabs,line_ids,prevent_copy=" >
2018-12-29 23:27:18 +00:00
< meta name = "colorscheme" content = "minimal-light" >
2018-08-14 04:25:22 +00:00
< style type = "text/css" >
<!--
2018-12-29 23:27:18 +00:00
pre { white-space: pre-wrap; font-family: monospace; color: #000000; background-color: #c6c6c6; }
body { font-size:12pt; font-family: monospace; color: #000000; background-color: #c6c6c6; }
2018-12-30 08:02:42 +00:00
a { color:inherit; }
2018-12-01 22:13:33 +00:00
* { font-size:12pt; font-size: 1em; }
2018-12-29 23:27:18 +00:00
.CommentedCode { color: #8a8a8a; }
.LineNr { }
2020-10-05 18:00:05 +00:00
.SpecialChar { color: #d70000; }
2018-12-29 23:27:18 +00:00
.Constant { color: #008787; }
2019-07-14 16:42:36 +00:00
.Comment { color: #005faf; }
.Normal { color: #000000; background-color: #c6c6c6; padding-bottom: 1px; }
2018-12-29 23:27:18 +00:00
.Identifier { color: #af5f00; }
2019-07-14 16:42:36 +00:00
.Delimiter { color: #c000c0; }
2019-03-29 07:47:30 +00:00
.PreProc { color: #c000c0; }
2019-07-14 16:42:36 +00:00
.SalientComment { color: #0000af; }
2018-08-14 04:25:22 +00:00
-->
< / style >
< script type = 'text/javascript' >
<!--
/* function to open any folds containing a jumped-to line before jumping to it */
function JumpToLine()
{
var lineNum;
lineNum = window.location.hash;
lineNum = lineNum.substr(1); /* strip off '#' */
if (lineNum.indexOf('L') == -1) {
lineNum = 'L'+lineNum;
}
2019-07-14 16:42:36 +00:00
var lineElem = document.getElementById(lineNum);
2018-08-14 04:25:22 +00:00
/* Always jump to new location even if the line was hidden inside a fold, or
* we corrected the raw number to a line ID.
*/
if (lineElem) {
lineElem.scrollIntoView(true);
}
return true;
}
if ('onhashchange' in window) {
window.onhashchange = JumpToLine;
}
-->
< / script >
< / head >
< body onload = 'JumpToLine();' >
2020-12-30 17:37:50 +00:00
< a href = 'https://github.com/akkartik/mu/blob/main/033check_operands.cc' > https://github.com/akkartik/mu/blob/main/033check_operands.cc< / a >
2018-08-14 04:25:22 +00:00
< pre id = 'vimCodeElement' >
2020-10-05 18:00:05 +00:00
< span id = "L1" class = "LineNr" > 1 < / span > < span class = "Comment" > //: Since we're tagging arguments with their types, let's start checking these< / span >
< span id = "L2" class = "LineNr" > 2 < / span > < span class = "Comment" > //: argument types for each instruction.< / span >
2018-08-14 04:25:22 +00:00
< span id = "L3" class = "LineNr" > 3 < / span >
2020-10-05 18:00:05 +00:00
< span id = "L4" class = "LineNr" > 4 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L4' > test_check_missing_imm8_argument< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
< span id = "L5" class = "LineNr" > 5 < / span > < span class = "SpecialChar" > Hide_errors< / span > = < span class = "Constant" > true< / span > < span class = "Delimiter" > ;< / span >
2020-01-14 09:48:06 +00:00
< span id = "L6" class = "LineNr" > 6 < / span > < a href = '011run.cc.html#L82' > run< / a > < span class = "Delimiter" > (< / span >
2019-05-20 08:44:06 +00:00
< span id = "L7" class = "LineNr" > 7 < / span > < span class = "Constant" > " == code 0x1\n" < / span >
2019-03-29 07:47:30 +00:00
< span id = "L8" class = "LineNr" > 8 < / span > < span class = "Constant" > " cd\n" < / span > < span class = "Comment" > // interrupt ??< / span >
< span id = "L9" class = "LineNr" > 9 < / span > < span class = "Delimiter" > );< / span >
2020-10-05 18:00:05 +00:00
< span id = "L10" class = "LineNr" > 10 < / span > < a href = '003trace.cc.html#L290' > CHECK_TRACE_CONTENTS< / a > < span class = "Delimiter" > (< / span >
< span id = "L11" class = "LineNr" > 11 < / span > < span class = "Constant" > " error: 'cd' (software interrupt): missing imm8 argument\n" < / span >
2019-03-29 07:47:30 +00:00
< span id = "L12" class = "LineNr" > 12 < / span > < span class = "Delimiter" > );< / span >
< span id = "L13" class = "LineNr" > 13 < / span > < span class = "Delimiter" > }< / span >
< span id = "L14" class = "LineNr" > 14 < / span >
< span id = "L15" class = "LineNr" > 15 < / span > < span class = "Delimiter" > :(before " Pack Operands(segment code)" )< / span >
2020-10-05 18:00:05 +00:00
< span id = "L16" class = "LineNr" > 16 < / span > check_arguments< span class = "Delimiter" > (< / span > code< span class = "Delimiter" > );< / span >
< span id = "L17" class = "LineNr" > 17 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > < a href = '003trace.cc.html#L262' > trace_contains_errors< / a > < span class = "Delimiter" > ())< / span > < span class = "Identifier" > return< / span > < span class = "Delimiter" > ;< / span >
2019-03-29 07:47:30 +00:00
< span id = "L18" class = "LineNr" > 18 < / span >
< span id = "L19" class = "LineNr" > 19 < / span > < span class = "Delimiter" > :(code)< / span >
2020-10-05 18:00:05 +00:00
< span id = "L20" class = "LineNr" > 20 < / span > < span class = "Normal" > void< / span > check_arguments< span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > segment& code< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L21" class = "LineNr" > 21 < / span > < a href = '003trace.cc.html#L96' > trace< / a > < span class = "Delimiter" > (< / span > < span class = "Constant" > 3< / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " transform" < / span > < span class = "Delimiter" > )< / span > < < < span class = "Constant" > " -- check arguments" < / span > < < end< span class = "Delimiter" > ();< / span >
< span id = "L22" class = "LineNr" > 22 < / span > < span class = "Normal" > for< / span > < span class = "Delimiter" > (< / span > < span class = "Normal" > int< / span > i = < span class = "Constant" > 0< / span > < span class = "Delimiter" > ;< / span > i < < a href = '001help.cc.html#L166' > SIZE< / a > < span class = "Delimiter" > (< / span > code< span class = "Delimiter" > .< / span > < a href = '011run.cc.html#L113' > lines< / a > < span class = "Delimiter" > );< / span > ++i< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L23" class = "LineNr" > 23 < / span > check_arguments< span class = "Delimiter" > (< / span > code< span class = "Delimiter" > .< / span > < a href = '011run.cc.html#L113' > lines< / a > < span class = "Delimiter" > .< / span > at< span class = "Delimiter" > (< / span > i< span class = "Delimiter" > ));< / span >
< span id = "L24" class = "LineNr" > 24 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > < a href = '003trace.cc.html#L262' > trace_contains_errors< / a > < span class = "Delimiter" > ())< / span > < span class = "Identifier" > return< / span > < span class = "Delimiter" > ;< / span > < span class = "Comment" > // stop at the first mal-formed instruction< / span >
2019-03-29 07:47:30 +00:00
< span id = "L25" class = "LineNr" > 25 < / span > < span class = "Delimiter" > }< / span >
< span id = "L26" class = "LineNr" > 26 < / span > < span class = "Delimiter" > }< / span >
< span id = "L27" class = "LineNr" > 27 < / span >
2020-10-05 18:00:05 +00:00
< span id = "L28" class = "LineNr" > 28 < / span > < span class = "Normal" > void< / span > check_arguments< span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > line& inst< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
2020-01-14 09:48:06 +00:00
< span id = "L29" class = "LineNr" > 29 < / span > < a href = '011run.cc.html#L127' > word< / a > op = < a href = '033check_operands.cc.html#L41' > preprocess_op< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > .< / span > < a href = '011run.cc.html#L122' > words< / a > < span class = "Delimiter" > .< / span > at< span class = "Delimiter" > (< / span > < span class = "Constant" > 0< / span > < span class = "Delimiter" > ));< / span >
2019-03-29 07:47:30 +00:00
< span id = "L30" class = "LineNr" > 30 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > op< span class = "Delimiter" > .< / span > data == < span class = "Constant" > " 0f" < / span > < span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
2020-10-05 18:00:05 +00:00
< span id = "L31" class = "LineNr" > 31 < / span > check_arguments_0f< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > );< / span >
2019-03-29 07:47:30 +00:00
< span id = "L32" class = "LineNr" > 32 < / span > < span class = "Identifier" > return< / span > < span class = "Delimiter" > ;< / span >
< span id = "L33" class = "LineNr" > 33 < / span > < span class = "Delimiter" > }< / span >
< span id = "L34" class = "LineNr" > 34 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > op< span class = "Delimiter" > .< / span > data == < span class = "Constant" > " f3" < / span > < span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
2020-10-05 18:00:05 +00:00
< span id = "L35" class = "LineNr" > 35 < / span > check_arguments_f3< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > );< / span >
2019-03-29 07:47:30 +00:00
< span id = "L36" class = "LineNr" > 36 < / span > < span class = "Identifier" > return< / span > < span class = "Delimiter" > ;< / span >
< span id = "L37" class = "LineNr" > 37 < / span > < span class = "Delimiter" > }< / span >
2020-10-05 18:00:05 +00:00
< span id = "L38" class = "LineNr" > 38 < / span > check_arguments< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > );< / span >
2019-03-29 07:47:30 +00:00
< span id = "L39" class = "LineNr" > 39 < / span > < span class = "Delimiter" > }< / span >
< span id = "L40" class = "LineNr" > 40 < / span >
2020-01-14 09:48:06 +00:00
< span id = "L41" class = "LineNr" > 41 < / span > < a href = '011run.cc.html#L127' > word< / a > < a href = '033check_operands.cc.html#L41' > preprocess_op< / a > < span class = "Delimiter" > (< / span > < a href = '011run.cc.html#L127' > word< / a > < span class = "Comment" > /*< / span > < span class = "Comment" > copy< / span > < span class = "Comment" > */< / span > op< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
2020-10-05 18:00:05 +00:00
< span id = "L42" class = "LineNr" > 42 < / span > op< span class = "Delimiter" > .< / span > data = < a href = '033check_operands.cc.html#L774' > tolower< / a > < span class = "Delimiter" > (< / span > op< span class = "Delimiter" > .< / span > data< span class = "Delimiter" > .< / span > c_str< span class = "Delimiter" > ());< / span >
2019-03-29 07:47:30 +00:00
< span id = "L43" class = "LineNr" > 43 < / span > < span class = "Comment" > // opcodes can't be negative< / span >
2020-10-05 18:00:05 +00:00
< span id = "L44" class = "LineNr" > 44 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > < a href = '001help.cc.html#L102' > starts_with< / a > < span class = "Delimiter" > (< / span > op< span class = "Delimiter" > .< / span > data< span class = "Delimiter" > ,< / span > < span class = "Constant" > " 0x" < / span > < span class = "Delimiter" > ))< / span >
2019-03-29 07:47:30 +00:00
< span id = "L45" class = "LineNr" > 45 < / span > op< span class = "Delimiter" > .< / span > data = op< span class = "Delimiter" > .< / span > data< span class = "Delimiter" > .< / span > substr< span class = "Delimiter" > (< / span > < span class = "Constant" > 2< / span > < span class = "Delimiter" > );< / span >
2020-10-05 18:00:05 +00:00
< span id = "L46" class = "LineNr" > 46 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > < a href = '001help.cc.html#L166' > SIZE< / a > < span class = "Delimiter" > (< / span > op< span class = "Delimiter" > .< / span > data< span class = "Delimiter" > )< / span > == < span class = "Constant" > 1< / span > < span class = "Delimiter" > )< / span >
2019-03-29 07:47:30 +00:00
< span id = "L47" class = "LineNr" > 47 < / span > op< span class = "Delimiter" > .< / span > data = string< span class = "Delimiter" > (< / span > < span class = "Constant" > " 0" < / span > < span class = "Delimiter" > )< / span > +op< span class = "Delimiter" > .< / span > data< span class = "Delimiter" > ;< / span >
< span id = "L48" class = "LineNr" > 48 < / span > < span class = "Identifier" > return< / span > op< span class = "Delimiter" > ;< / span >
< span id = "L49" class = "LineNr" > 49 < / span > < span class = "Delimiter" > }< / span >
< span id = "L50" class = "LineNr" > 50 < / span >
2019-12-09 09:32:48 +00:00
< span id = "L51" class = "LineNr" > 51 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L51' > test_preprocess_op< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
2020-01-14 09:48:06 +00:00
< span id = "L52" class = "LineNr" > 52 < / span > < a href = '011run.cc.html#L127' > word< / a > w1< span class = "Delimiter" > ;< / span > w1< span class = "Delimiter" > .< / span > data = < span class = "Constant" > " 0xf" < / span > < span class = "Delimiter" > ;< / span >
< span id = "L53" class = "LineNr" > 53 < / span > < a href = '011run.cc.html#L127' > word< / a > w2< span class = "Delimiter" > ;< / span > w2< span class = "Delimiter" > .< / span > data = < span class = "Constant" > " 0f" < / span > < span class = "Delimiter" > ;< / span >
2019-12-09 09:32:48 +00:00
< span id = "L54" class = "LineNr" > 54 < / span > < a href = '002test.cc.html#L31' > CHECK_EQ< / a > < span class = "Delimiter" > (< / span > < a href = '033check_operands.cc.html#L41' > preprocess_op< / a > < span class = "Delimiter" > (< / span > w1< span class = "Delimiter" > ).< / span > data< span class = "Delimiter" > ,< / span > < a href = '033check_operands.cc.html#L41' > preprocess_op< / a > < span class = "Delimiter" > (< / span > w2< span class = "Delimiter" > ).< / span > data< span class = "Delimiter" > );< / span >
2019-03-29 07:47:30 +00:00
< span id = "L55" class = "LineNr" > 55 < / span > < span class = "Delimiter" > }< / span >
< span id = "L56" class = "LineNr" > 56 < / span >
2020-10-05 18:00:05 +00:00
< span id = "L57" class = "LineNr" > 57 < / span > < span class = "Comment" > //: To check the arguments for an opcode, we'll track the permitted arguments< / span >
2019-03-29 07:47:30 +00:00
< span id = "L58" class = "LineNr" > 58 < / span > < span class = "Comment" > //: for each supported opcode in a bitvector. That way we can often compute the< / span >
2020-10-05 18:00:05 +00:00
< span id = "L59" class = "LineNr" > 59 < / span > < span class = "Comment" > //: 'received' argument bitvector for each instruction's arguments and compare< / span >
2019-03-29 07:47:30 +00:00
< span id = "L60" class = "LineNr" > 60 < / span > < span class = "Comment" > //: it with the 'expected' bitvector.< / span >
< span id = "L61" class = "LineNr" > 61 < / span > < span class = "Comment" > //:< / span >
< span id = "L62" class = "LineNr" > 62 < / span > < span class = "Comment" > //: The 'expected' and 'received' bitvectors can be different; the MODRM bit< / span >
2020-10-05 18:00:05 +00:00
< span id = "L63" class = "LineNr" > 63 < / span > < span class = "Comment" > //: in the 'expected' bitvector maps to multiple 'received' argument types in< / span >
2019-03-29 07:47:30 +00:00
< span id = "L64" class = "LineNr" > 64 < / span > < span class = "Comment" > //: an instruction. We deal in expected bitvectors throughout.< / span >
< span id = "L65" class = "LineNr" > 65 < / span >
< span id = "L66" class = "LineNr" > 66 < / span > < span class = "Delimiter" > :(before " End Types" )< / span >
2020-10-05 18:00:05 +00:00
< span id = "L67" class = "LineNr" > 67 < / span > < span class = "Normal" > enum< / span > < a href = '033check_operands.cc.html#L67' > expected_argument_type< / a > < span class = "Delimiter" > {< / span >
2019-03-29 07:47:30 +00:00
< span id = "L68" class = "LineNr" > 68 < / span > < span class = "Comment" > // start from the least significant bit< / span >
2019-12-09 09:32:48 +00:00
< span id = "L69" class = "LineNr" > 69 < / span > < a href = '033check_operands.cc.html#L69' > MODRM< / a > < span class = "Delimiter" > ,< / span > < span class = "Comment" > // more complex, may also involve disp8 or disp32< / span >
< span id = "L70" class = "LineNr" > 70 < / span > < a href = '033check_operands.cc.html#L70' > SUBOP< / a > < span class = "Delimiter" > ,< / span >
< span id = "L71" class = "LineNr" > 71 < / span > < a href = '033check_operands.cc.html#L71' > DISP8< / a > < span class = "Delimiter" > ,< / span >
< span id = "L72" class = "LineNr" > 72 < / span > < a href = '033check_operands.cc.html#L72' > DISP16< / a > < span class = "Delimiter" > ,< / span >
< span id = "L73" class = "LineNr" > 73 < / span > < a href = '033check_operands.cc.html#L73' > DISP32< / a > < span class = "Delimiter" > ,< / span >
< span id = "L74" class = "LineNr" > 74 < / span > < a href = '033check_operands.cc.html#L74' > IMM8< / a > < span class = "Delimiter" > ,< / span >
< span id = "L75" class = "LineNr" > 75 < / span > < a href = '033check_operands.cc.html#L75' > IMM32< / a > < span class = "Delimiter" > ,< / span >
< span id = "L76" class = "LineNr" > 76 < / span > < a href = '033check_operands.cc.html#L76' > NUM_OPERAND_TYPES< / a >
2019-03-29 07:47:30 +00:00
< span id = "L77" class = "LineNr" > 77 < / span > < span class = "Delimiter" > };< / span >
< span id = "L78" class = "LineNr" > 78 < / span > < span class = "Delimiter" > :(before " End Globals" )< / span >
2020-10-05 18:00:05 +00:00
< span id = "L79" class = "LineNr" > 79 < / span > vector< string> < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L79' > Operand_type_name< / a > < / span > < span class = "Delimiter" > ;< / span >
< span id = "L80" class = "LineNr" > 80 < / span > map< string< span class = "Delimiter" > ,< / span > expected_argument_type> < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L80' > Operand_type< / a > < / span > < span class = "Delimiter" > ;< / span >
2019-03-29 07:47:30 +00:00
< span id = "L81" class = "LineNr" > 81 < / span > < span class = "Delimiter" > :(before " End One-time Setup" )< / span >
2019-12-09 09:32:48 +00:00
< span id = "L82" class = "LineNr" > 82 < / span > < a href = '033check_operands.cc.html#L84' > init_op_types< / a > < span class = "Delimiter" > ();< / span >
2019-03-29 07:47:30 +00:00
< span id = "L83" class = "LineNr" > 83 < / span > < span class = "Delimiter" > :(code)< / span >
2019-12-09 09:32:48 +00:00
< span id = "L84" class = "LineNr" > 84 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L84' > init_op_types< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
< span id = "L85" class = "LineNr" > 85 < / span > assert< span class = "Delimiter" > (< / span > < a href = '033check_operands.cc.html#L76' > NUM_OPERAND_TYPES< / a > < = < span class = "Comment" > /*< / span > < span class = "Comment" > bits in a uint8_t< / span > < span class = "Comment" > */< / span > < span class = "Constant" > 8< / span > < span class = "Delimiter" > );< / span >
2020-10-05 18:00:05 +00:00
< span id = "L86" class = "LineNr" > 86 < / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L79' > Operand_type_name< / a > < / span > < span class = "Delimiter" > .< / span > resize< span class = "Delimiter" > (< / span > < a href = '033check_operands.cc.html#L76' > NUM_OPERAND_TYPES< / a > < span class = "Delimiter" > );< / span >
< span id = "L87" class = "LineNr" > 87 < / span > < span class = "PreProc" > #define DEF(type) < / span > < span class = "SpecialChar" > Operand_type_name< / span > < span class = "Delimiter" > .< / span > < span class = "PreProc" > at(type) = tolower(#type)< / span > < span class = "Delimiter" > ,< / span > < span class = "PreProc" > put(< / span > < span class = "SpecialChar" > Operand_type< / span > < span class = "Delimiter" > ,< / span > < span class = "PreProc" > tolower(#type)< / span > < span class = "Delimiter" > ,< / span > < span class = "PreProc" > type)< / span > < span class = "Delimiter" > ;< / span >
2019-12-09 09:32:48 +00:00
< span id = "L88" class = "LineNr" > 88 < / span > DEF< span class = "Delimiter" > (< / span > < a href = '033check_operands.cc.html#L69' > MODRM< / a > < span class = "Delimiter" > );< / span >
< span id = "L89" class = "LineNr" > 89 < / span > DEF< span class = "Delimiter" > (< / span > < a href = '033check_operands.cc.html#L70' > SUBOP< / a > < span class = "Delimiter" > );< / span >
< span id = "L90" class = "LineNr" > 90 < / span > DEF< span class = "Delimiter" > (< / span > < a href = '033check_operands.cc.html#L71' > DISP8< / a > < span class = "Delimiter" > );< / span >
< span id = "L91" class = "LineNr" > 91 < / span > DEF< span class = "Delimiter" > (< / span > < a href = '033check_operands.cc.html#L72' > DISP16< / a > < span class = "Delimiter" > );< / span >
< span id = "L92" class = "LineNr" > 92 < / span > DEF< span class = "Delimiter" > (< / span > < a href = '033check_operands.cc.html#L73' > DISP32< / a > < span class = "Delimiter" > );< / span >
< span id = "L93" class = "LineNr" > 93 < / span > DEF< span class = "Delimiter" > (< / span > < a href = '033check_operands.cc.html#L74' > IMM8< / a > < span class = "Delimiter" > );< / span >
< span id = "L94" class = "LineNr" > 94 < / span > DEF< span class = "Delimiter" > (< / span > < a href = '033check_operands.cc.html#L75' > IMM32< / a > < span class = "Delimiter" > );< / span >
2019-03-29 07:47:30 +00:00
< span id = "L95" class = "LineNr" > 95 < / span > < span class = "PreProc" > #undef DEF< / span >
< span id = "L96" class = "LineNr" > 96 < / span > < span class = "Delimiter" > }< / span >
< span id = "L97" class = "LineNr" > 97 < / span >
< span id = "L98" class = "LineNr" > 98 < / span > < span class = "Delimiter" > :(before " End Globals" )< / span >
2020-10-05 18:00:05 +00:00
< span id = "L99" class = "LineNr" > 99 < / span > map< < span class = "Comment" > /*< / span > < span class = "Comment" > op< / span > < span class = "Comment" > */< / span > string< span class = "Delimiter" > ,< / span > < span class = "Comment" > /*< / span > < span class = "Comment" > bitvector< / span > < span class = "Comment" > */< / span > < span class = "Normal" > uint8_t< / span > > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ;< / span >
< span id = "L100" class = "LineNr" > 100 < / span > < span class = "Normal" > const< / span > < span class = "Normal" > uint8_t< / span > < a href = '033check_operands.cc.html#L100' > INVALID_OPERANDS< / a > = < span class = "Constant" > 0xff< / span > < span class = "Delimiter" > ;< / span > < span class = "Comment" > // no instruction uses all the argument types< / span >
2019-03-29 07:47:30 +00:00
< span id = "L101" class = "LineNr" > 101 < / span > < span class = "Delimiter" > :(before " End One-time Setup" )< / span >
2020-10-05 18:00:05 +00:00
< span id = "L102" class = "LineNr" > 102 < / span > < a href = '033check_operands.cc.html#L104' > init_permitted_arguments< / a > < span class = "Delimiter" > ();< / span >
2019-03-29 07:47:30 +00:00
< span id = "L103" class = "LineNr" > 103 < / span > < span class = "Delimiter" > :(code)< / span >
2020-10-05 18:00:05 +00:00
< span id = "L104" class = "LineNr" > 104 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L104' > init_permitted_arguments< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
< span id = "L105" class = "LineNr" > 105 < / span > < span class = "SalientComment" > //// Class A: just op, no arguments< / span >
2019-03-29 07:47:30 +00:00
< span id = "L106" class = "LineNr" > 106 < / span > < span class = "Comment" > // halt< / span >
2020-10-05 18:00:05 +00:00
< span id = "L107" class = "LineNr" > 107 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " f4" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
2019-03-29 07:47:30 +00:00
< span id = "L108" class = "LineNr" > 108 < / span > < span class = "Comment" > // inc< / span >
2020-10-05 18:00:05 +00:00
< span id = "L109" class = "LineNr" > 109 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 40" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L110" class = "LineNr" > 110 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 41" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L111" class = "LineNr" > 111 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 42" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L112" class = "LineNr" > 112 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 43" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L113" class = "LineNr" > 113 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 44" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L114" class = "LineNr" > 114 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 45" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L115" class = "LineNr" > 115 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 46" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L116" class = "LineNr" > 116 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 47" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
2019-03-29 07:47:30 +00:00
< span id = "L117" class = "LineNr" > 117 < / span > < span class = "Comment" > // dec< / span >
2020-10-05 18:00:05 +00:00
< span id = "L118" class = "LineNr" > 118 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 48" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L119" class = "LineNr" > 119 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 49" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L120" class = "LineNr" > 120 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 4a" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L121" class = "LineNr" > 121 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 4b" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L122" class = "LineNr" > 122 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 4c" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L123" class = "LineNr" > 123 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 4d" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L124" class = "LineNr" > 124 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 4e" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L125" class = "LineNr" > 125 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 4f" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
2019-03-29 07:47:30 +00:00
< span id = "L126" class = "LineNr" > 126 < / span > < span class = "Comment" > // push< / span >
2020-10-05 18:00:05 +00:00
< span id = "L127" class = "LineNr" > 127 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 50" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L128" class = "LineNr" > 128 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 51" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L129" class = "LineNr" > 129 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 52" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L130" class = "LineNr" > 130 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 53" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L131" class = "LineNr" > 131 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 54" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L132" class = "LineNr" > 132 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 55" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L133" class = "LineNr" > 133 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 56" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L134" class = "LineNr" > 134 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 57" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
2019-03-29 07:47:30 +00:00
< span id = "L135" class = "LineNr" > 135 < / span > < span class = "Comment" > // pop< / span >
2020-10-05 18:00:05 +00:00
< span id = "L136" class = "LineNr" > 136 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 58" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L137" class = "LineNr" > 137 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 59" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L138" class = "LineNr" > 138 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 5a" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L139" class = "LineNr" > 139 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 5b" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L140" class = "LineNr" > 140 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 5c" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L141" class = "LineNr" > 141 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 5d" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L142" class = "LineNr" > 142 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 5e" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
< span id = "L143" class = "LineNr" > 143 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 5f" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
2019-05-20 08:44:06 +00:00
< span id = "L144" class = "LineNr" > 144 < / span > < span class = "Comment" > // sign-extend EAX into EDX< / span >
2020-10-05 18:00:05 +00:00
< span id = "L145" class = "LineNr" > 145 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 99" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
2019-05-20 08:44:06 +00:00
< span id = "L146" class = "LineNr" > 146 < / span > < span class = "Comment" > // return< / span >
2020-10-05 18:00:05 +00:00
< span id = "L147" class = "LineNr" > 147 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " c3" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x00< / span > < span class = "Delimiter" > );< / span >
2019-05-20 08:44:06 +00:00
< span id = "L148" class = "LineNr" > 148 < / span >
< span id = "L149" class = "LineNr" > 149 < / span > < span class = "SalientComment" > //// Class B: just op and disp8< / span >
< span id = "L150" class = "LineNr" > 150 < / span > < span class = "Comment" > // imm32 imm8 disp32 |disp16 disp8 subop modrm< / span >
< span id = "L151" class = "LineNr" > 151 < / span > < span class = "Comment" > // 0 0 0 |0 1 0 0< / span >
< span id = "L152" class = "LineNr" > 152 < / span >
< span id = "L153" class = "LineNr" > 153 < / span > < span class = "Comment" > // jump< / span >
2020-10-05 18:00:05 +00:00
< span id = "L154" class = "LineNr" > 154 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " eb" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x04< / span > < span class = "Delimiter" > );< / span >
< span id = "L155" class = "LineNr" > 155 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 72" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x04< / span > < span class = "Delimiter" > );< / span >
< span id = "L156" class = "LineNr" > 156 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 73" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x04< / span > < span class = "Delimiter" > );< / span >
< span id = "L157" class = "LineNr" > 157 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 74" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x04< / span > < span class = "Delimiter" > );< / span >
< span id = "L158" class = "LineNr" > 158 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 75" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x04< / span > < span class = "Delimiter" > );< / span >
< span id = "L159" class = "LineNr" > 159 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 76" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x04< / span > < span class = "Delimiter" > );< / span >
< span id = "L160" class = "LineNr" > 160 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 77" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x04< / span > < span class = "Delimiter" > );< / span >
< span id = "L161" class = "LineNr" > 161 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 7c" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x04< / span > < span class = "Delimiter" > );< / span >
< span id = "L162" class = "LineNr" > 162 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 7d" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x04< / span > < span class = "Delimiter" > );< / span >
< span id = "L163" class = "LineNr" > 163 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 7e" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x04< / span > < span class = "Delimiter" > );< / span >
< span id = "L164" class = "LineNr" > 164 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 7f" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x04< / span > < span class = "Delimiter" > );< / span >
2018-12-29 23:27:18 +00:00
< span id = "L165" class = "LineNr" > 165 < / span >
2019-05-20 08:44:06 +00:00
< span id = "L166" class = "LineNr" > 166 < / span > < span class = "SalientComment" > //// Class D: just op and disp32< / span >
2018-12-29 23:27:18 +00:00
< span id = "L167" class = "LineNr" > 167 < / span > < span class = "Comment" > // imm32 imm8 disp32 |disp16 disp8 subop modrm< / span >
2019-05-20 08:44:06 +00:00
< span id = "L168" class = "LineNr" > 168 < / span > < span class = "Comment" > // 0 0 1 |0 0 0 0< / span >
2020-10-05 18:00:05 +00:00
< span id = "L169" class = "LineNr" > 169 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " e8" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x10< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // call< / span >
< span id = "L170" class = "LineNr" > 170 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " e9" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x10< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // jump< / span >
2019-05-20 08:44:06 +00:00
< span id = "L171" class = "LineNr" > 171 < / span >
< span id = "L172" class = "LineNr" > 172 < / span > < span class = "SalientComment" > //// Class E: just op and imm8< / span >
< span id = "L173" class = "LineNr" > 173 < / span > < span class = "Comment" > // imm32 imm8 disp32 |disp16 disp8 subop modrm< / span >
< span id = "L174" class = "LineNr" > 174 < / span > < span class = "Comment" > // 0 1 0 |0 0 0 0< / span >
2020-10-05 18:00:05 +00:00
< span id = "L175" class = "LineNr" > 175 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " cd" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x20< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // software interrupt< / span >
2019-05-20 08:44:06 +00:00
< span id = "L176" class = "LineNr" > 176 < / span >
< span id = "L177" class = "LineNr" > 177 < / span > < span class = "SalientComment" > //// Class F: just op and imm32< / span >
< span id = "L178" class = "LineNr" > 178 < / span > < span class = "Comment" > // imm32 imm8 disp32 |disp16 disp8 subop modrm< / span >
< span id = "L179" class = "LineNr" > 179 < / span > < span class = "Comment" > // 1 0 0 |0 0 0 0< / span >
2020-10-05 18:00:05 +00:00
< span id = "L180" class = "LineNr" > 180 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 05" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x40< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // add< / span >
< span id = "L181" class = "LineNr" > 181 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 2d" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x40< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // subtract< / span >
< span id = "L182" class = "LineNr" > 182 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 25" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x40< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // and< / span >
< span id = "L183" class = "LineNr" > 183 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 0d" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x40< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // or< / span >
< span id = "L184" class = "LineNr" > 184 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 35" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x40< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // xor< / span >
< span id = "L185" class = "LineNr" > 185 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 3d" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x40< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // compare< / span >
< span id = "L186" class = "LineNr" > 186 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 68" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x40< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // push< / span >
2019-05-20 08:44:06 +00:00
< span id = "L187" class = "LineNr" > 187 < / span > < span class = "Comment" > // copy< / span >
2020-10-05 18:00:05 +00:00
< span id = "L188" class = "LineNr" > 188 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " b8" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x40< / span > < span class = "Delimiter" > );< / span >
< span id = "L189" class = "LineNr" > 189 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " b9" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x40< / span > < span class = "Delimiter" > );< / span >
< span id = "L190" class = "LineNr" > 190 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " ba" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x40< / span > < span class = "Delimiter" > );< / span >
< span id = "L191" class = "LineNr" > 191 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " bb" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x40< / span > < span class = "Delimiter" > );< / span >
< span id = "L192" class = "LineNr" > 192 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " bc" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x40< / span > < span class = "Delimiter" > );< / span >
< span id = "L193" class = "LineNr" > 193 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " bd" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x40< / span > < span class = "Delimiter" > );< / span >
< span id = "L194" class = "LineNr" > 194 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " be" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x40< / span > < span class = "Delimiter" > );< / span >
< span id = "L195" class = "LineNr" > 195 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " bf" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x40< / span > < span class = "Delimiter" > );< / span >
2019-05-20 08:44:06 +00:00
< span id = "L196" class = "LineNr" > 196 < / span >
< span id = "L197" class = "LineNr" > 197 < / span > < span class = "SalientComment" > //// Class M: using ModR/M byte< / span >
< span id = "L198" class = "LineNr" > 198 < / span > < span class = "Comment" > // imm32 imm8 disp32 |disp16 disp8 subop modrm< / span >
< span id = "L199" class = "LineNr" > 199 < / span > < span class = "Comment" > // 0 0 0 |0 0 0 1< / span >
< span id = "L200" class = "LineNr" > 200 < / span >
< span id = "L201" class = "LineNr" > 201 < / span > < span class = "Comment" > // add< / span >
2020-10-05 18:00:05 +00:00
< span id = "L202" class = "LineNr" > 202 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 01" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
< span id = "L203" class = "LineNr" > 203 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 03" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
2019-05-20 08:44:06 +00:00
< span id = "L204" class = "LineNr" > 204 < / span > < span class = "Comment" > // subtract< / span >
2020-10-05 18:00:05 +00:00
< span id = "L205" class = "LineNr" > 205 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 29" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
< span id = "L206" class = "LineNr" > 206 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 2b" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
2019-05-20 08:44:06 +00:00
< span id = "L207" class = "LineNr" > 207 < / span > < span class = "Comment" > // and< / span >
2020-10-05 18:00:05 +00:00
< span id = "L208" class = "LineNr" > 208 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 21" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
< span id = "L209" class = "LineNr" > 209 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 23" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
2019-05-20 08:44:06 +00:00
< span id = "L210" class = "LineNr" > 210 < / span > < span class = "Comment" > // or< / span >
2020-10-05 18:00:05 +00:00
< span id = "L211" class = "LineNr" > 211 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 09" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
< span id = "L212" class = "LineNr" > 212 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 0b" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
2019-05-20 08:44:06 +00:00
< span id = "L213" class = "LineNr" > 213 < / span > < span class = "Comment" > // xor< / span >
2020-10-05 18:00:05 +00:00
< span id = "L214" class = "LineNr" > 214 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 31" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
< span id = "L215" class = "LineNr" > 215 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 33" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
2019-05-20 08:44:06 +00:00
< span id = "L216" class = "LineNr" > 216 < / span > < span class = "Comment" > // compare< / span >
2020-10-05 18:00:05 +00:00
< span id = "L217" class = "LineNr" > 217 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 39" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
< span id = "L218" class = "LineNr" > 218 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 3b" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
2019-05-20 08:44:06 +00:00
< span id = "L219" class = "LineNr" > 219 < / span > < span class = "Comment" > // copy< / span >
2020-10-05 18:00:05 +00:00
< span id = "L220" class = "LineNr" > 220 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 88" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
< span id = "L221" class = "LineNr" > 221 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 89" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
< span id = "L222" class = "LineNr" > 222 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 8a" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
< span id = "L223" class = "LineNr" > 223 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 8b" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
2019-05-20 08:44:06 +00:00
< span id = "L224" class = "LineNr" > 224 < / span > < span class = "Comment" > // swap< / span >
2020-10-05 18:00:05 +00:00
< span id = "L225" class = "LineNr" > 225 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 87" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
2019-05-20 08:44:06 +00:00
< span id = "L226" class = "LineNr" > 226 < / span > < span class = "Comment" > // copy address (lea)< / span >
2020-10-05 18:00:05 +00:00
< span id = "L227" class = "LineNr" > 227 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 8d" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
2019-07-14 16:42:36 +00:00
< span id = "L228" class = "LineNr" > 228 < / span >
< span id = "L229" class = "LineNr" > 229 < / span > < span class = "SalientComment" > //// Class N: op, ModR/M and subop (not r32)< / span >
< span id = "L230" class = "LineNr" > 230 < / span > < span class = "Comment" > // imm32 imm8 disp32 |disp16 disp8 subop modrm< / span >
< span id = "L231" class = "LineNr" > 231 < / span > < span class = "Comment" > // 0 0 0 |0 0 1 1< / span >
2020-10-05 18:00:05 +00:00
< span id = "L232" class = "LineNr" > 232 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 8f" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x03< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // pop< / span >
< span id = "L233" class = "LineNr" > 233 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " d3" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x03< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // shift< / span >
< span id = "L234" class = "LineNr" > 234 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " f7" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x03< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // test/not/mul/div< / span >
< span id = "L235" class = "LineNr" > 235 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " ff" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x03< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // jump/push/call< / span >
2019-07-14 16:42:36 +00:00
< span id = "L236" class = "LineNr" > 236 < / span >
< span id = "L237" class = "LineNr" > 237 < / span > < span class = "SalientComment" > //// Class O: op, ModR/M, subop (not r32) and imm8< / span >
< span id = "L238" class = "LineNr" > 238 < / span > < span class = "Comment" > // imm32 imm8 disp32 |disp16 disp8 subop modrm< / span >
< span id = "L239" class = "LineNr" > 239 < / span > < span class = "Comment" > // 0 1 0 |0 0 1 1< / span >
2020-10-05 18:00:05 +00:00
< span id = "L240" class = "LineNr" > 240 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " c1" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x23< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // combine< / span >
< span id = "L241" class = "LineNr" > 241 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " c6" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x23< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // copy< / span >
2019-07-14 16:42:36 +00:00
< span id = "L242" class = "LineNr" > 242 < / span >
< span id = "L243" class = "LineNr" > 243 < / span > < span class = "SalientComment" > //// Class P: op, ModR/M, subop (not r32) and imm32< / span >
< span id = "L244" class = "LineNr" > 244 < / span > < span class = "Comment" > // imm32 imm8 disp32 |disp16 disp8 subop modrm< / span >
< span id = "L245" class = "LineNr" > 245 < / span > < span class = "Comment" > // 1 0 0 |0 0 1 1< / span >
2020-10-05 18:00:05 +00:00
< span id = "L246" class = "LineNr" > 246 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 81" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x43< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // combine< / span >
< span id = "L247" class = "LineNr" > 247 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " c7" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x43< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // copy< / span >
2019-07-14 16:42:36 +00:00
< span id = "L248" class = "LineNr" > 248 < / span >
2020-03-07 02:39:16 +00:00
< span id = "L249" class = "LineNr" > 249 < / span > < span class = "SalientComment" > //// Class Q: op, ModR/M and imm32< / span >
< span id = "L250" class = "LineNr" > 250 < / span > < span class = "Comment" > // imm32 imm8 disp32 |disp16 disp8 subop modrm< / span >
< span id = "L251" class = "LineNr" > 251 < / span > < span class = "Comment" > // 1 0 0 |0 0 0 1< / span >
2020-10-05 18:00:05 +00:00
< span id = "L252" class = "LineNr" > 252 < / span > < a href = '001help.cc.html#L225' > put< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 69" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x41< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // multiply< / span >
2020-03-07 02:39:16 +00:00
< span id = "L253" class = "LineNr" > 253 < / span >
< span id = "L254" class = "LineNr" > 254 < / span > < span class = "Comment" > // End Init Permitted Operands< / span >
< span id = "L255" class = "LineNr" > 255 < / span > < span class = "Delimiter" > }< / span >
< span id = "L256" class = "LineNr" > 256 < / span >
< span id = "L257" class = "LineNr" > 257 < / span > < span class = "PreProc" > #define HAS(bitvector< / span > < span class = "Delimiter" > ,< / span > < span class = "PreProc" > bit) ((bitvector) & (< / span > < span class = "Constant" > 1< / span > < span class = "PreProc" > < < (bit)))< / span >
< span id = "L258" class = "LineNr" > 258 < / span > < span class = "PreProc" > #define SET(bitvector< / span > < span class = "Delimiter" > ,< / span > < span class = "PreProc" > bit) ((bitvector) | (< / span > < span class = "Constant" > 1< / span > < span class = "PreProc" > < < (bit)))< / span >
< span id = "L259" class = "LineNr" > 259 < / span > < span class = "PreProc" > #define CLEAR(bitvector< / span > < span class = "Delimiter" > ,< / span > < span class = "PreProc" > bit) ((bitvector) & (~(< / span > < span class = "Constant" > 1< / span > < span class = "PreProc" > < < (bit))))< / span >
< span id = "L260" class = "LineNr" > 260 < / span >
2020-10-05 18:00:05 +00:00
< span id = "L261" class = "LineNr" > 261 < / span > < span class = "Normal" > void< / span > check_arguments< span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > line& inst< span class = "Delimiter" > ,< / span > < span class = "Normal" > const< / span > word& op< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
2020-03-07 02:39:16 +00:00
< span id = "L262" class = "LineNr" > 262 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > !is_hex_byte< span class = "Delimiter" > (< / span > op< span class = "Delimiter" > ))< / span > < span class = "Identifier" > return< / span > < span class = "Delimiter" > ;< / span >
2020-10-05 18:00:05 +00:00
< span id = "L263" class = "LineNr" > 263 < / span > < span class = "Normal" > uint8_t< / span > expected_bitvector = get< span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L99' > Permitted_arguments< / a > < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > .< / span > data< span class = "Delimiter" > );< / span >
2020-03-07 02:39:16 +00:00
< span id = "L264" class = "LineNr" > 264 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > HAS< span class = "Delimiter" > (< / span > expected_bitvector< span class = "Delimiter" > ,< / span > < a href = '033check_operands.cc.html#L69' > MODRM< / a > < span class = "Delimiter" > ))< / span > < span class = "Delimiter" > {< / span >
2020-10-05 18:00:05 +00:00
< span id = "L265" class = "LineNr" > 265 < / span > < a href = '033check_operands.cc.html#L377' > check_arguments_modrm< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > );< / span >
< span id = "L266" class = "LineNr" > 266 < / span > < a href = '033check_operands.cc.html#L412' > compare_bitvector_modrm< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > expected_bitvector< span class = "Delimiter" > ,< / span > < a href = '033check_operands.cc.html#L293' > maybe_name< / a > < span class = "Delimiter" > (< / span > op< span class = "Delimiter" > ));< / span >
2020-03-07 02:39:16 +00:00
< span id = "L267" class = "LineNr" > 267 < / span > < span class = "Delimiter" > }< / span >
< span id = "L268" class = "LineNr" > 268 < / span > < span class = "Normal" > else< / span > < span class = "Delimiter" > {< / span >
< span id = "L269" class = "LineNr" > 269 < / span > < a href = '033check_operands.cc.html#L275' > compare_bitvector< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > expected_bitvector< span class = "Delimiter" > ,< / span > < a href = '033check_operands.cc.html#L293' > maybe_name< / a > < span class = "Delimiter" > (< / span > op< span class = "Delimiter" > ));< / span >
< span id = "L270" class = "LineNr" > 270 < / span > < span class = "Delimiter" > }< / span >
< span id = "L271" class = "LineNr" > 271 < / span > < span class = "Delimiter" > }< / span >
< span id = "L272" class = "LineNr" > 272 < / span >
< span id = "L273" class = "LineNr" > 273 < / span > < span class = "Comment" > //: Many instructions can be checked just by comparing bitvectors.< / span >
< span id = "L274" class = "LineNr" > 274 < / span >
< span id = "L275" class = "LineNr" > 275 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L275' > compare_bitvector< / a > < span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > line& inst< span class = "Delimiter" > ,< / span > < span class = "Normal" > uint8_t< / span > expected< span class = "Delimiter" > ,< / span > < span class = "Normal" > const< / span > string& maybe_op_name< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
2020-10-05 18:00:05 +00:00
< span id = "L276" class = "LineNr" > 276 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > < a href = '032operands.cc.html#L531' > all_hex_bytes< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > )< / span > & & < a href = '033check_operands.cc.html#L311' > has_arguments< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ))< / span > < span class = "Identifier" > return< / span > < span class = "Delimiter" > ;< / span > < span class = "Comment" > // deliberately programming in raw hex; we'll raise a warning elsewhere< / span >
< span id = "L277" class = "LineNr" > 277 < / span > < span class = "Normal" > uint8_t< / span > bitvector = < a href = '033check_operands.cc.html#L301' > compute_expected_argument_bitvector< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > );< / span >
< span id = "L278" class = "LineNr" > 278 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > < a href = '003trace.cc.html#L262' > trace_contains_errors< / a > < span class = "Delimiter" > ())< / span > < span class = "Identifier" > return< / span > < span class = "Delimiter" > ;< / span > < span class = "Comment" > // duplicate argument type< / span >
2020-03-07 02:39:16 +00:00
< span id = "L279" class = "LineNr" > 279 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > bitvector == expected< span class = "Delimiter" > )< / span > < span class = "Identifier" > return< / span > < span class = "Delimiter" > ;< / span > < span class = "Comment" > // all good with this instruction< / span >
< span id = "L280" class = "LineNr" > 280 < / span > < span class = "Normal" > for< / span > < span class = "Delimiter" > (< / span > < span class = "Normal" > int< / span > i = < span class = "Constant" > 0< / span > < span class = "Delimiter" > ;< / span > i < < a href = '033check_operands.cc.html#L76' > NUM_OPERAND_TYPES< / a > < span class = "Delimiter" > ;< / span > ++i< span class = "Delimiter" > ,< / span > bitvector > > = < span class = "Constant" > 1< / span > < span class = "Delimiter" > ,< / span > expected > > = < span class = "Constant" > 1< / span > < span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L281" class = "LineNr" > 281 < / span > < span class = "CommentedCode" > //? cerr < < " comparing " < < HEXBYTE < < NUM(bitvector) < < " with " < < NUM(expected) < < '\n';< / span >
2020-10-05 18:00:05 +00:00
< span id = "L282" class = "LineNr" > 282 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > ((< / span > bitvector & < span class = "Constant" > 0x1< / span > < span class = "Delimiter" > )< / span > == < span class = "Delimiter" > (< / span > expected & < span class = "Constant" > 0x1< / span > < span class = "Delimiter" > ))< / span > < span class = "Identifier" > continue< / span > < span class = "Delimiter" > ;< / span > < span class = "Comment" > // all good with this argument< / span >
< span id = "L283" class = "LineNr" > 283 < / span > < span class = "Normal" > const< / span > string& optype = < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L79' > Operand_type_name< / a > < / span > < span class = "Delimiter" > .< / span > at< span class = "Delimiter" > (< / span > i< span class = "Delimiter" > );< / span >
2020-03-07 02:39:16 +00:00
< span id = "L284" class = "LineNr" > 284 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > ((< / span > bitvector & < span class = "Constant" > 0x1< / span > < span class = "Delimiter" > )< / span > > < span class = "Delimiter" > (< / span > expected & < span class = "Constant" > 0x1< / span > < span class = "Delimiter" > ))< / span >
2020-10-05 18:00:05 +00:00
< span id = "L285" class = "LineNr" > 285 < / span > < a href = '003trace.cc.html#L226' > raise< / a > < < < span class = "Constant" > " '" < / span > < < to_string< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > )< / span > < < < span class = "Constant" > " '" < / span > < < maybe_op_name < < < span class = "Constant" > " : unexpected " < / span > < < optype < < < span class = "Constant" > " argument\n" < / span > < < end< span class = "Delimiter" > ();< / span >
2020-03-07 02:39:16 +00:00
< span id = "L286" class = "LineNr" > 286 < / span > < span class = "Normal" > else< / span >
2020-10-05 18:00:05 +00:00
< span id = "L287" class = "LineNr" > 287 < / span > < a href = '003trace.cc.html#L226' > raise< / a > < < < span class = "Constant" > " '" < / span > < < to_string< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > )< / span > < < < span class = "Constant" > " '" < / span > < < maybe_op_name < < < span class = "Constant" > " : missing " < / span > < < optype < < < span class = "Constant" > " argument\n" < / span > < < end< span class = "Delimiter" > ();< / span >
2020-03-07 02:39:16 +00:00
< span id = "L288" class = "LineNr" > 288 < / span > < span class = "Comment" > // continue giving all errors for a single instruction< / span >
< span id = "L289" class = "LineNr" > 289 < / span > < span class = "Delimiter" > }< / span >
< span id = "L290" class = "LineNr" > 290 < / span > < span class = "Comment" > // ignore settings in any unused bits< / span >
< span id = "L291" class = "LineNr" > 291 < / span > < span class = "Delimiter" > }< / span >
< span id = "L292" class = "LineNr" > 292 < / span >
< span id = "L293" class = "LineNr" > 293 < / span > string < a href = '033check_operands.cc.html#L293' > maybe_name< / a > < span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > word& op< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L294" class = "LineNr" > 294 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > !is_hex_byte< span class = "Delimiter" > (< / span > op< span class = "Delimiter" > ))< / span > < span class = "Identifier" > return< / span > < span class = "Constant" > " " < / span > < span class = "Delimiter" > ;< / span >
2020-10-05 18:00:05 +00:00
< span id = "L295" class = "LineNr" > 295 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > !contains_key< span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '010vm.cc.html#L355' > Name< / a > < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > .< / span > data< span class = "Delimiter" > ))< / span > < span class = "Identifier" > return< / span > < span class = "Constant" > " " < / span > < span class = "Delimiter" > ;< / span >
2020-03-07 02:39:16 +00:00
< span id = "L296" class = "LineNr" > 296 < / span > < span class = "Comment" > // strip stuff in parens from the name< / span >
2020-10-05 18:00:05 +00:00
< span id = "L297" class = "LineNr" > 297 < / span > < span class = "Normal" > const< / span > string& s = get< span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '010vm.cc.html#L355' > Name< / a > < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > .< / span > data< span class = "Delimiter" > );< / span >
2020-03-07 02:39:16 +00:00
< span id = "L298" class = "LineNr" > 298 < / span > < span class = "Identifier" > return< / span > < span class = "Constant" > " (" < / span > +s< span class = "Delimiter" > .< / span > substr< span class = "Delimiter" > (< / span > < span class = "Constant" > 0< / span > < span class = "Delimiter" > ,< / span > s< span class = "Delimiter" > .< / span > find< span class = "Delimiter" > (< / span > < span class = "Constant" > " (" < / span > < span class = "Delimiter" > ))< / span > +< span class = "Constant" > ')'< / span > < span class = "Delimiter" > ;< / span >
< span id = "L299" class = "LineNr" > 299 < / span > < span class = "Delimiter" > }< / span >
< span id = "L300" class = "LineNr" > 300 < / span >
2020-10-05 18:00:05 +00:00
< span id = "L301" class = "LineNr" > 301 < / span > < span class = "Normal" > uint32_t< / span > < a href = '033check_operands.cc.html#L301' > compute_expected_argument_bitvector< / a > < span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > line& inst< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L302" class = "LineNr" > 302 < / span > set< string> arguments_found< span class = "Delimiter" > ;< / span >
2020-03-07 02:39:16 +00:00
< span id = "L303" class = "LineNr" > 303 < / span > < span class = "Normal" > uint32_t< / span > bitvector = < span class = "Constant" > 0< / span > < span class = "Delimiter" > ;< / span >
2020-10-05 18:00:05 +00:00
< span id = "L304" class = "LineNr" > 304 < / span > < span class = "Normal" > for< / span > < span class = "Delimiter" > (< / span > < span class = "Normal" > int< / span > i = < span class = "Comment" > /*< / span > < span class = "Comment" > skip op< / span > < span class = "Comment" > */< / span > < span class = "Constant" > 1< / span > < span class = "Delimiter" > ;< / span > i < < a href = '001help.cc.html#L166' > SIZE< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > .< / span > < a href = '011run.cc.html#L122' > words< / a > < span class = "Delimiter" > );< / span > ++i< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L305" class = "LineNr" > 305 < / span > bitvector = bitvector | < a href = '033check_operands.cc.html#L328' > expected_bit_for_received_argument< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > .< / span > < a href = '011run.cc.html#L122' > words< / a > < span class = "Delimiter" > .< / span > at< span class = "Delimiter" > (< / span > i< span class = "Delimiter" > ),< / span > arguments_found< span class = "Delimiter" > ,< / span > inst< span class = "Delimiter" > );< / span >
< span id = "L306" class = "LineNr" > 306 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > < a href = '003trace.cc.html#L262' > trace_contains_errors< / a > < span class = "Delimiter" > ())< / span > < span class = "Identifier" > return< / span > < a href = '033check_operands.cc.html#L100' > INVALID_OPERANDS< / a > < span class = "Delimiter" > ;< / span > < span class = "Comment" > // duplicate argument type< / span >
2020-03-07 02:39:16 +00:00
< span id = "L307" class = "LineNr" > 307 < / span > < span class = "Delimiter" > }< / span >
< span id = "L308" class = "LineNr" > 308 < / span > < span class = "Identifier" > return< / span > bitvector< span class = "Delimiter" > ;< / span >
< span id = "L309" class = "LineNr" > 309 < / span > < span class = "Delimiter" > }< / span >
< span id = "L310" class = "LineNr" > 310 < / span >
2020-10-05 18:00:05 +00:00
< span id = "L311" class = "LineNr" > 311 < / span > < span class = "Normal" > bool< / span > < a href = '033check_operands.cc.html#L311' > has_arguments< / a > < span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > line& inst< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L312" class = "LineNr" > 312 < / span > < span class = "Identifier" > return< / span > < a href = '001help.cc.html#L166' > SIZE< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > .< / span > < a href = '011run.cc.html#L122' > words< / a > < span class = "Delimiter" > )< / span > > < a href = '033check_operands.cc.html#L315' > first_argument< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > );< / span >
2020-03-07 02:39:16 +00:00
< span id = "L313" class = "LineNr" > 313 < / span > < span class = "Delimiter" > }< / span >
< span id = "L314" class = "LineNr" > 314 < / span >
2020-10-05 18:00:05 +00:00
< span id = "L315" class = "LineNr" > 315 < / span > < span class = "Normal" > int< / span > < a href = '033check_operands.cc.html#L315' > first_argument< / a > < span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > line& inst< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
2020-03-07 02:39:16 +00:00
< span id = "L316" class = "LineNr" > 316 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > .< / span > < a href = '011run.cc.html#L122' > words< / a > < span class = "Delimiter" > .< / span > at< span class = "Delimiter" > (< / span > < span class = "Constant" > 0< / span > < span class = "Delimiter" > ).< / span > data == < span class = "Constant" > " 0f" < / span > < span class = "Delimiter" > )< / span > < span class = "Identifier" > return< / span > < span class = "Constant" > 2< / span > < span class = "Delimiter" > ;< / span >
< span id = "L317" class = "LineNr" > 317 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > .< / span > < a href = '011run.cc.html#L122' > words< / a > < span class = "Delimiter" > .< / span > at< span class = "Delimiter" > (< / span > < span class = "Constant" > 0< / span > < span class = "Delimiter" > ).< / span > data == < span class = "Constant" > " f2" < / span > || inst< span class = "Delimiter" > .< / span > < a href = '011run.cc.html#L122' > words< / a > < span class = "Delimiter" > .< / span > at< span class = "Delimiter" > (< / span > < span class = "Constant" > 0< / span > < span class = "Delimiter" > ).< / span > data == < span class = "Constant" > " f3" < / span > < span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L318" class = "LineNr" > 318 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > .< / span > < a href = '011run.cc.html#L122' > words< / a > < span class = "Delimiter" > .< / span > at< span class = "Delimiter" > (< / span > < span class = "Constant" > 1< / span > < span class = "Delimiter" > ).< / span > data == < span class = "Constant" > " 0f" < / span > < span class = "Delimiter" > )< / span >
< span id = "L319" class = "LineNr" > 319 < / span > < span class = "Identifier" > return< / span > < span class = "Constant" > 3< / span > < span class = "Delimiter" > ;< / span >
< span id = "L320" class = "LineNr" > 320 < / span > < span class = "Normal" > else< / span >
< span id = "L321" class = "LineNr" > 321 < / span > < span class = "Identifier" > return< / span > < span class = "Constant" > 2< / span > < span class = "Delimiter" > ;< / span >
< span id = "L322" class = "LineNr" > 322 < / span > < span class = "Delimiter" > }< / span >
< span id = "L323" class = "LineNr" > 323 < / span > < span class = "Identifier" > return< / span > < span class = "Constant" > 1< / span > < span class = "Delimiter" > ;< / span >
< span id = "L324" class = "LineNr" > 324 < / span > < span class = "Delimiter" > }< / span >
< span id = "L325" class = "LineNr" > 325 < / span >
2020-10-05 18:00:05 +00:00
< span id = "L326" class = "LineNr" > 326 < / span > < span class = "Comment" > // Scan the metadata of 'w' and return the expected bit corresponding to any argument type.< / span >
< span id = "L327" class = "LineNr" > 327 < / span > < span class = "Comment" > // Also raise an error if metadata contains multiple argument types.< / span >
< span id = "L328" class = "LineNr" > 328 < / span > < span class = "Normal" > uint32_t< / span > < a href = '033check_operands.cc.html#L328' > expected_bit_for_received_argument< / a > < span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > word& w< span class = "Delimiter" > ,< / span > set< string> & instruction_arguments< span class = "Delimiter" > ,< / span > < span class = "Normal" > const< / span > line& inst< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
2020-03-07 02:39:16 +00:00
< span id = "L329" class = "LineNr" > 329 < / span > < span class = "Normal" > uint32_t< / span > bv = < span class = "Constant" > 0< / span > < span class = "Delimiter" > ;< / span >
< span id = "L330" class = "LineNr" > 330 < / span > < span class = "Normal" > bool< / span > found = < span class = "Constant" > false< / span > < span class = "Delimiter" > ;< / span >
2020-10-05 18:00:05 +00:00
< span id = "L331" class = "LineNr" > 331 < / span > < span class = "Normal" > for< / span > < span class = "Delimiter" > (< / span > < span class = "Normal" > int< / span > i = < span class = "Constant" > 0< / span > < span class = "Delimiter" > ;< / span > i < < a href = '001help.cc.html#L166' > SIZE< / a > < span class = "Delimiter" > (< / span > w< span class = "Delimiter" > .< / span > metadata< span class = "Delimiter" > );< / span > ++i< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
2020-03-07 02:39:16 +00:00
< span id = "L332" class = "LineNr" > 332 < / span > string< span class = "Comment" > /*< / span > < span class = "Comment" > copy< / span > < span class = "Comment" > */< / span > curr = w< span class = "Delimiter" > .< / span > metadata< span class = "Delimiter" > .< / span > at< span class = "Delimiter" > (< / span > i< span class = "Delimiter" > );< / span >
< span id = "L333" class = "LineNr" > 333 < / span > string expected_metadata = curr< span class = "Delimiter" > ;< / span >
2020-10-05 18:00:05 +00:00
< span id = "L334" class = "LineNr" > 334 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > curr == < span class = "Constant" > " mod" < / span > || curr == < span class = "Constant" > " rm32" < / span > || curr == < span class = "Constant" > " r32" < / span > || curr == < span class = "Constant" > " xm32" < / span > || curr == < span class = "Constant" > " x32" < / span > || curr == < span class = "Constant" > " scale" < / span > || curr == < span class = "Constant" > " index" < / span > || curr == < span class = "Constant" > " base" < / span > < span class = "Delimiter" > )< / span >
2020-03-07 02:39:16 +00:00
< span id = "L335" class = "LineNr" > 335 < / span > expected_metadata = < span class = "Constant" > " modrm" < / span > < span class = "Delimiter" > ;< / span >
2020-10-05 18:00:05 +00:00
< span id = "L336" class = "LineNr" > 336 < / span > < span class = "Normal" > else< / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > !contains_key< span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L80' > Operand_type< / a > < / span > < span class = "Delimiter" > ,< / span > curr< span class = "Delimiter" > ))< / span > < span class = "Identifier" > continue< / span > < span class = "Delimiter" > ;< / span > < span class = "Comment" > // ignore unrecognized metadata< / span >
2020-03-07 02:39:16 +00:00
< span id = "L337" class = "LineNr" > 337 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > found< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
2020-10-05 18:00:05 +00:00
< span id = "L338" class = "LineNr" > 338 < / span > < a href = '003trace.cc.html#L226' > raise< / a > < < < span class = "Constant" > " '" < / span > < < w< span class = "Delimiter" > .< / span > original < < < span class = "Constant" > " ' has conflicting argument types; it should have only one\n" < / span > < < end< span class = "Delimiter" > ();< / span >
2020-03-07 02:39:16 +00:00
< span id = "L339" class = "LineNr" > 339 < / span > < span class = "Identifier" > return< / span > < a href = '033check_operands.cc.html#L100' > INVALID_OPERANDS< / a > < span class = "Delimiter" > ;< / span >
< span id = "L340" class = "LineNr" > 340 < / span > < span class = "Delimiter" > }< / span >
2020-10-05 18:00:05 +00:00
< span id = "L341" class = "LineNr" > 341 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > instruction_arguments< span class = "Delimiter" > .< / span > find< span class = "Delimiter" > (< / span > curr< span class = "Delimiter" > )< / span > != instruction_arguments< span class = "Delimiter" > .< / span > end< span class = "Delimiter" > ())< / span > < span class = "Delimiter" > {< / span >
< span id = "L342" class = "LineNr" > 342 < / span > < a href = '003trace.cc.html#L226' > raise< / a > < < < span class = "Constant" > " '" < / span > < < to_string< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > )< / span > < < < span class = "Constant" > " ': duplicate " < / span > < < curr < < < span class = "Constant" > " argument\n" < / span > < < end< span class = "Delimiter" > ();< / span >
2020-03-07 02:39:16 +00:00
< span id = "L343" class = "LineNr" > 343 < / span > < span class = "Identifier" > return< / span > < a href = '033check_operands.cc.html#L100' > INVALID_OPERANDS< / a > < span class = "Delimiter" > ;< / span >
< span id = "L344" class = "LineNr" > 344 < / span > < span class = "Delimiter" > }< / span >
2020-10-05 18:00:05 +00:00
< span id = "L345" class = "LineNr" > 345 < / span > instruction_arguments< span class = "Delimiter" > .< / span > insert< span class = "Delimiter" > (< / span > curr< span class = "Delimiter" > );< / span >
< span id = "L346" class = "LineNr" > 346 < / span > bv = < span class = "Delimiter" > (< / span > < span class = "Constant" > 1< / span > < < get< span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L80' > Operand_type< / a > < / span > < span class = "Delimiter" > ,< / span > expected_metadata< span class = "Delimiter" > ));< / span >
2020-03-07 02:39:16 +00:00
< span id = "L347" class = "LineNr" > 347 < / span > found = < span class = "Constant" > true< / span > < span class = "Delimiter" > ;< / span >
< span id = "L348" class = "LineNr" > 348 < / span > < span class = "Delimiter" > }< / span >
< span id = "L349" class = "LineNr" > 349 < / span > < span class = "Identifier" > return< / span > bv< span class = "Delimiter" > ;< / span >
< span id = "L350" class = "LineNr" > 350 < / span > < span class = "Delimiter" > }< / span >
< span id = "L351" class = "LineNr" > 351 < / span >
2020-10-05 18:00:05 +00:00
< span id = "L352" class = "LineNr" > 352 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L352' > test_conflicting_argument_type< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
< span id = "L353" class = "LineNr" > 353 < / span > < span class = "SpecialChar" > Hide_errors< / span > = < span class = "Constant" > true< / span > < span class = "Delimiter" > ;< / span >
2020-03-07 02:39:16 +00:00
< span id = "L354" class = "LineNr" > 354 < / span > < a href = '011run.cc.html#L82' > run< / a > < span class = "Delimiter" > (< / span >
< span id = "L355" class = "LineNr" > 355 < / span > < span class = "Constant" > " == code 0x1\n" < / span >
< span id = "L356" class = "LineNr" > 356 < / span > < span class = "Constant" > " cd/software-interrupt 80/imm8/imm32\n" < / span >
< span id = "L357" class = "LineNr" > 357 < / span > < span class = "Delimiter" > );< / span >
2020-10-05 18:00:05 +00:00
< span id = "L358" class = "LineNr" > 358 < / span > < a href = '003trace.cc.html#L290' > CHECK_TRACE_CONTENTS< / a > < span class = "Delimiter" > (< / span >
< span id = "L359" class = "LineNr" > 359 < / span > < span class = "Constant" > " error: '80/imm8/imm32' has conflicting argument types; it should have only one\n" < / span >
2020-03-07 02:39:16 +00:00
< span id = "L360" class = "LineNr" > 360 < / span > < span class = "Delimiter" > );< / span >
< span id = "L361" class = "LineNr" > 361 < / span > < span class = "Delimiter" > }< / span >
< span id = "L362" class = "LineNr" > 362 < / span >
< span id = "L363" class = "LineNr" > 363 < / span > < span class = "Comment" > //: Instructions computing effective addresses have more complex rules, so< / span >
< span id = "L364" class = "LineNr" > 364 < / span > < span class = "Comment" > //: we'll hard-code a common set of instruction-decoding rules.< / span >
< span id = "L365" class = "LineNr" > 365 < / span >
2020-10-05 18:00:05 +00:00
< span id = "L366" class = "LineNr" > 366 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L366' > test_check_missing_mod_argument< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
< span id = "L367" class = "LineNr" > 367 < / span > < span class = "SpecialChar" > Hide_errors< / span > = < span class = "Constant" > true< / span > < span class = "Delimiter" > ;< / span >
2020-03-07 02:39:16 +00:00
< span id = "L368" class = "LineNr" > 368 < / span > < a href = '011run.cc.html#L82' > run< / a > < span class = "Delimiter" > (< / span >
< span id = "L369" class = "LineNr" > 369 < / span > < span class = "Constant" > " == code 0x1\n" < / span >
< span id = "L370" class = "LineNr" > 370 < / span > < span class = "Constant" > " 81 0/add/subop 3/rm32/ebx 1/imm32\n" < / span >
< span id = "L371" class = "LineNr" > 371 < / span > < span class = "Delimiter" > );< / span >
2020-10-05 18:00:05 +00:00
< span id = "L372" class = "LineNr" > 372 < / span > < a href = '003trace.cc.html#L290' > CHECK_TRACE_CONTENTS< / a > < span class = "Delimiter" > (< / span >
< span id = "L373" class = "LineNr" > 373 < / span > < span class = "Constant" > " error: '81 0/add/subop 3/rm32/ebx 1/imm32' (combine rm32 with imm32 based on subop): missing mod argument\n" < / span >
2020-03-07 02:39:16 +00:00
< span id = "L374" class = "LineNr" > 374 < / span > < span class = "Delimiter" > );< / span >
< span id = "L375" class = "LineNr" > 375 < / span > < span class = "Delimiter" > }< / span >
< span id = "L376" class = "LineNr" > 376 < / span >
2020-10-05 18:00:05 +00:00
< span id = "L377" class = "LineNr" > 377 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L377' > check_arguments_modrm< / a > < span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > line& inst< span class = "Delimiter" > ,< / span > < span class = "Normal" > const< / span > word& op< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L378" class = "LineNr" > 378 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > < a href = '032operands.cc.html#L531' > all_hex_bytes< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ))< / span > < span class = "Identifier" > return< / span > < span class = "Delimiter" > ;< / span > < span class = "Comment" > // deliberately programming in raw hex; we'll raise a warning elsewhere< / span >
< span id = "L379" class = "LineNr" > 379 < / span > < a href = '033check_operands.cc.html#L446' > check_argument_metadata_present< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > < span class = "Constant" > " mod" < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > );< / span >
< span id = "L380" class = "LineNr" > 380 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > !has_argument_metadata< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > < span class = "Constant" > " rm32" < / span > < span class = "Delimiter" > )< / span > & & !has_argument_metadata< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > < span class = "Constant" > " xm32" < / span > < span class = "Delimiter" > ))< / span >
< span id = "L381" class = "LineNr" > 381 < / span > < a href = '003trace.cc.html#L226' > raise< / a > < < < span class = "Constant" > " '" < / span > < < to_string< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > )< / span > < < < span class = "Constant" > " '" < / span > < < < a href = '033check_operands.cc.html#L293' > maybe_name< / a > < span class = "Delimiter" > (< / span > op< span class = "Delimiter" > )< / span > < < < span class = "Constant" > " : missing rm32 (or xm32) argument\n" < / span > < < end< span class = "Delimiter" > ();< / span >
< span id = "L382" class = "LineNr" > 382 < / span > < span class = "Comment" > // no check for r32; some instructions don't use it; just assume it's 0 if missing< / span >
< span id = "L383" class = "LineNr" > 383 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > op< span class = "Delimiter" > .< / span > data == < span class = "Constant" > " 81" < / span > || op< span class = "Delimiter" > .< / span > data == < span class = "Constant" > " 8f" < / span > || op< span class = "Delimiter" > .< / span > data == < span class = "Constant" > " f7" < / span > || op< span class = "Delimiter" > .< / span > data == < span class = "Constant" > " ff" < / span > < span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span > < span class = "Comment" > // keep sync'd with 'help subop'< / span >
< span id = "L384" class = "LineNr" > 384 < / span > < a href = '033check_operands.cc.html#L446' > check_argument_metadata_present< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > < span class = "Constant" > " subop" < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > );< / span >
< span id = "L385" class = "LineNr" > 385 < / span > < a href = '033check_operands.cc.html#L451' > check_argument_metadata_absent< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > < span class = "Constant" > " r32" < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > ,< / span > < span class = "Constant" > " should be replaced by subop" < / span > < span class = "Delimiter" > );< / span >
< span id = "L386" class = "LineNr" > 386 < / span > < a href = '033check_operands.cc.html#L451' > check_argument_metadata_absent< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > < span class = "Constant" > " x32" < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > ,< / span > < span class = "Constant" > " should be replaced by subop" < / span > < span class = "Delimiter" > );< / span >
< span id = "L387" class = "LineNr" > 387 < / span > < span class = "Delimiter" > }< / span >
< span id = "L388" class = "LineNr" > 388 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > < a href = '003trace.cc.html#L262' > trace_contains_errors< / a > < span class = "Delimiter" > ())< / span > < span class = "Identifier" > return< / span > < span class = "Delimiter" > ;< / span >
< span id = "L389" class = "LineNr" > 389 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > < a href = '033check_operands.cc.html#L403' > metadata_m32< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ).< / span > data != < span class = "Constant" > " 4" < / span > < span class = "Delimiter" > )< / span > < span class = "Identifier" > return< / span > < span class = "Delimiter" > ;< / span >
< span id = "L390" class = "LineNr" > 390 < / span > < span class = "Comment" > // SIB byte checks< / span >
< span id = "L391" class = "LineNr" > 391 < / span > < span class = "Normal" > uint8_t< / span > mod = < a href = '011run.cc.html#L288' > hex_byte< / a > < span class = "Delimiter" > (< / span > metadata< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > < span class = "Constant" > " mod" < / span > < span class = "Delimiter" > ).< / span > data< span class = "Delimiter" > );< / span >
< span id = "L392" class = "LineNr" > 392 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > mod != < span class = "Comment" > /*< / span > < span class = "Comment" > direct< / span > < span class = "Comment" > */< / span > < span class = "Constant" > 3< / span > < span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L393" class = "LineNr" > 393 < / span > < a href = '033check_operands.cc.html#L446' > check_argument_metadata_present< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > < span class = "Constant" > " base" < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > );< / span >
< span id = "L394" class = "LineNr" > 394 < / span > < a href = '033check_operands.cc.html#L446' > check_argument_metadata_present< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > < span class = "Constant" > " index" < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > );< / span > < span class = "Comment" > // otherwise why go to SIB?< / span >
< span id = "L395" class = "LineNr" > 395 < / span > < span class = "Delimiter" > }< / span >
< span id = "L396" class = "LineNr" > 396 < / span > < span class = "Normal" > else< / span > < span class = "Delimiter" > {< / span >
< span id = "L397" class = "LineNr" > 397 < / span > < a href = '033check_operands.cc.html#L451' > check_argument_metadata_absent< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > < span class = "Constant" > " base" < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > ,< / span > < span class = "Constant" > " direct mode" < / span > < span class = "Delimiter" > );< / span >
< span id = "L398" class = "LineNr" > 398 < / span > < a href = '033check_operands.cc.html#L451' > check_argument_metadata_absent< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > < span class = "Constant" > " index" < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > ,< / span > < span class = "Constant" > " direct mode" < / span > < span class = "Delimiter" > );< / span >
< span id = "L399" class = "LineNr" > 399 < / span > < span class = "Delimiter" > }< / span >
< span id = "L400" class = "LineNr" > 400 < / span > < span class = "Comment" > // no check for scale; 0 (2**0 = 1) by default< / span >
< span id = "L401" class = "LineNr" > 401 < / span > < span class = "Delimiter" > }< / span >
< span id = "L402" class = "LineNr" > 402 < / span >
< span id = "L403" class = "LineNr" > 403 < / span > < a href = '011run.cc.html#L127' > word< / a > < a href = '033check_operands.cc.html#L403' > metadata_m32< / a > < span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > line& inst< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L404" class = "LineNr" > 404 < / span > < span class = "Normal" > for< / span > < span class = "Delimiter" > (< / span > < span class = "Normal" > int< / span > i = < span class = "Constant" > 0< / span > < span class = "Delimiter" > ;< / span > i < < a href = '001help.cc.html#L166' > SIZE< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > .< / span > < a href = '011run.cc.html#L122' > words< / a > < span class = "Delimiter" > );< / span > ++i< span class = "Delimiter" > )< / span >
< span id = "L405" class = "LineNr" > 405 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > has_argument_metadata< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > .< / span > < a href = '011run.cc.html#L122' > words< / a > < span class = "Delimiter" > .< / span > at< span class = "Delimiter" > (< / span > i< span class = "Delimiter" > ),< / span > < span class = "Constant" > " rm32" < / span > < span class = "Delimiter" > )< / span > || has_argument_metadata< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > .< / span > < a href = '011run.cc.html#L122' > words< / a > < span class = "Delimiter" > .< / span > at< span class = "Delimiter" > (< / span > i< span class = "Delimiter" > ),< / span > < span class = "Constant" > " xm32" < / span > < span class = "Delimiter" > ))< / span >
< span id = "L406" class = "LineNr" > 406 < / span > < span class = "Identifier" > return< / span > inst< span class = "Delimiter" > .< / span > < a href = '011run.cc.html#L122' > words< / a > < span class = "Delimiter" > .< / span > at< span class = "Delimiter" > (< / span > i< span class = "Delimiter" > );< / span >
< span id = "L407" class = "LineNr" > 407 < / span > assert< span class = "Delimiter" > (< / span > < span class = "Constant" > false< / span > < span class = "Delimiter" > );< / span >
< span id = "L408" class = "LineNr" > 408 < / span > < span class = "Delimiter" > }< / span >
< span id = "L409" class = "LineNr" > 409 < / span >
< span id = "L410" class = "LineNr" > 410 < / span > < span class = "Comment" > // same as compare_bitvector, with one additional exception for modrm-based< / span >
< span id = "L411" class = "LineNr" > 411 < / span > < span class = "Comment" > // instructions: they may use an extra displacement on occasion< / span >
< span id = "L412" class = "LineNr" > 412 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L412' > compare_bitvector_modrm< / a > < span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > line& inst< span class = "Delimiter" > ,< / span > < span class = "Normal" > uint8_t< / span > expected< span class = "Delimiter" > ,< / span > < span class = "Normal" > const< / span > string& maybe_op_name< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L413" class = "LineNr" > 413 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > < a href = '032operands.cc.html#L531' > all_hex_bytes< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > )< / span > & & < a href = '033check_operands.cc.html#L311' > has_arguments< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ))< / span > < span class = "Identifier" > return< / span > < span class = "Delimiter" > ;< / span > < span class = "Comment" > // deliberately programming in raw hex; we'll raise a warning elsewhere< / span >
< span id = "L414" class = "LineNr" > 414 < / span > < span class = "Normal" > uint8_t< / span > bitvector = < a href = '033check_operands.cc.html#L301' > compute_expected_argument_bitvector< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > );< / span >
< span id = "L415" class = "LineNr" > 415 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > < a href = '003trace.cc.html#L262' > trace_contains_errors< / a > < span class = "Delimiter" > ())< / span > < span class = "Identifier" > return< / span > < span class = "Delimiter" > ;< / span > < span class = "Comment" > // duplicate argument type< / span >
< span id = "L416" class = "LineNr" > 416 < / span > < span class = "Comment" > // update 'expected' bitvector for the additional exception< / span >
< span id = "L417" class = "LineNr" > 417 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > has_argument_metadata< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > < span class = "Constant" > " mod" < / span > < span class = "Delimiter" > ))< / span > < span class = "Delimiter" > {< / span >
< span id = "L418" class = "LineNr" > 418 < / span > < span class = "Normal" > int32_t< / span > mod = < a href = '032operands.cc.html#L608' > parse_int< / a > < span class = "Delimiter" > (< / span > metadata< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > < span class = "Constant" > " mod" < / span > < span class = "Delimiter" > ).< / span > data< span class = "Delimiter" > );< / span >
< span id = "L419" class = "LineNr" > 419 < / span > < span class = "Normal" > switch< / span > < span class = "Delimiter" > (< / span > mod< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L420" class = "LineNr" > 420 < / span > < span class = "Normal" > case< / span > < span class = "Constant" > 0< / span > :
< span id = "L421" class = "LineNr" > 421 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > has_argument_metadata< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > < span class = "Constant" > " rm32" < / span > < span class = "Delimiter" > )< / span > & & < a href = '032operands.cc.html#L608' > parse_int< / a > < span class = "Delimiter" > (< / span > metadata< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > < span class = "Constant" > " rm32" < / span > < span class = "Delimiter" > ).< / span > data< span class = "Delimiter" > )< / span > == < span class = "Constant" > 5< / span > < span class = "Delimiter" > )< / span >
< span id = "L422" class = "LineNr" > 422 < / span > expected |= < span class = "Delimiter" > (< / span > < span class = "Constant" > 1< / span > < < DISP32< span class = "Delimiter" > );< / span >
< span id = "L423" class = "LineNr" > 423 < / span > < span class = "Identifier" > break< / span > < span class = "Delimiter" > ;< / span >
< span id = "L424" class = "LineNr" > 424 < / span > < span class = "Normal" > case< / span > < span class = "Constant" > 1< / span > :
< span id = "L425" class = "LineNr" > 425 < / span > expected |= < span class = "Delimiter" > (< / span > < span class = "Constant" > 1< / span > < < DISP8< span class = "Delimiter" > );< / span >
< span id = "L426" class = "LineNr" > 426 < / span > < span class = "Identifier" > break< / span > < span class = "Delimiter" > ;< / span >
< span id = "L427" class = "LineNr" > 427 < / span > < span class = "Normal" > case< / span > < span class = "Constant" > 2< / span > :
< span id = "L428" class = "LineNr" > 428 < / span > expected |= < span class = "Delimiter" > (< / span > < span class = "Constant" > 1< / span > < < DISP32< span class = "Delimiter" > );< / span >
< span id = "L429" class = "LineNr" > 429 < / span > < span class = "Identifier" > break< / span > < span class = "Delimiter" > ;< / span >
< span id = "L430" class = "LineNr" > 430 < / span > < span class = "Delimiter" > }< / span >
< span id = "L431" class = "LineNr" > 431 < / span > < span class = "Delimiter" > }< / span >
< span id = "L432" class = "LineNr" > 432 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > bitvector == expected< span class = "Delimiter" > )< / span > < span class = "Identifier" > return< / span > < span class = "Delimiter" > ;< / span > < span class = "Comment" > // all good with this instruction< / span >
< span id = "L433" class = "LineNr" > 433 < / span > < span class = "Normal" > for< / span > < span class = "Delimiter" > (< / span > < span class = "Normal" > int< / span > i = < span class = "Constant" > 0< / span > < span class = "Delimiter" > ;< / span > i < < a href = '033check_operands.cc.html#L76' > NUM_OPERAND_TYPES< / a > < span class = "Delimiter" > ;< / span > ++i< span class = "Delimiter" > ,< / span > bitvector > > = < span class = "Constant" > 1< / span > < span class = "Delimiter" > ,< / span > expected > > = < span class = "Constant" > 1< / span > < span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L434" class = "LineNr" > 434 < / span > < span class = "CommentedCode" > //? cerr < < " comparing for modrm " < < HEXBYTE < < NUM(bitvector) < < " with " < < NUM(expected) < < '\n';< / span >
< span id = "L435" class = "LineNr" > 435 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > ((< / span > bitvector & < span class = "Constant" > 0x1< / span > < span class = "Delimiter" > )< / span > == < span class = "Delimiter" > (< / span > expected & < span class = "Constant" > 0x1< / span > < span class = "Delimiter" > ))< / span > < span class = "Identifier" > continue< / span > < span class = "Delimiter" > ;< / span > < span class = "Comment" > // all good with this argument< / span >
< span id = "L436" class = "LineNr" > 436 < / span > < span class = "Normal" > const< / span > string& optype = < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L79' > Operand_type_name< / a > < / span > < span class = "Delimiter" > .< / span > at< span class = "Delimiter" > (< / span > i< span class = "Delimiter" > );< / span >
< span id = "L437" class = "LineNr" > 437 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > ((< / span > bitvector & < span class = "Constant" > 0x1< / span > < span class = "Delimiter" > )< / span > > < span class = "Delimiter" > (< / span > expected & < span class = "Constant" > 0x1< / span > < span class = "Delimiter" > ))< / span >
< span id = "L438" class = "LineNr" > 438 < / span > < a href = '003trace.cc.html#L226' > raise< / a > < < < span class = "Constant" > " '" < / span > < < to_string< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > )< / span > < < < span class = "Constant" > " '" < / span > < < maybe_op_name < < < span class = "Constant" > " : unexpected " < / span > < < optype < < < span class = "Constant" > " argument\n" < / span > < < end< span class = "Delimiter" > ();< / span >
< span id = "L439" class = "LineNr" > 439 < / span > < span class = "Normal" > else< / span >
< span id = "L440" class = "LineNr" > 440 < / span > < a href = '003trace.cc.html#L226' > raise< / a > < < < span class = "Constant" > " '" < / span > < < to_string< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > )< / span > < < < span class = "Constant" > " '" < / span > < < maybe_op_name < < < span class = "Constant" > " : missing " < / span > < < optype < < < span class = "Constant" > " argument\n" < / span > < < end< span class = "Delimiter" > ();< / span >
< span id = "L441" class = "LineNr" > 441 < / span > < span class = "Comment" > // continue giving all errors for a single instruction< / span >
< span id = "L442" class = "LineNr" > 442 < / span > < span class = "Delimiter" > }< / span >
< span id = "L443" class = "LineNr" > 443 < / span > < span class = "Comment" > // ignore settings in any unused bits< / span >
< span id = "L444" class = "LineNr" > 444 < / span > < span class = "Delimiter" > }< / span >
< span id = "L445" class = "LineNr" > 445 < / span >
< span id = "L446" class = "LineNr" > 446 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L446' > check_argument_metadata_present< / a > < span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > line& inst< span class = "Delimiter" > ,< / span > < span class = "Normal" > const< / span > string& type< span class = "Delimiter" > ,< / span > < span class = "Normal" > const< / span > word& op< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L447" class = "LineNr" > 447 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > !has_argument_metadata< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > type< span class = "Delimiter" > ))< / span >
< span id = "L448" class = "LineNr" > 448 < / span > < a href = '003trace.cc.html#L226' > raise< / a > < < < span class = "Constant" > " '" < / span > < < to_string< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > )< / span > < < < span class = "Constant" > " '" < / span > < < < a href = '033check_operands.cc.html#L293' > maybe_name< / a > < span class = "Delimiter" > (< / span > op< span class = "Delimiter" > )< / span > < < < span class = "Constant" > " : missing " < / span > < < type < < < span class = "Constant" > " argument\n" < / span > < < end< span class = "Delimiter" > ();< / span >
< span id = "L449" class = "LineNr" > 449 < / span > < span class = "Delimiter" > }< / span >
< span id = "L450" class = "LineNr" > 450 < / span >
< span id = "L451" class = "LineNr" > 451 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L451' > check_argument_metadata_absent< / a > < span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > line& inst< span class = "Delimiter" > ,< / span > < span class = "Normal" > const< / span > string& type< span class = "Delimiter" > ,< / span > < span class = "Normal" > const< / span > word& op< span class = "Delimiter" > ,< / span > < span class = "Normal" > const< / span > string& msg< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L452" class = "LineNr" > 452 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > has_argument_metadata< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > type< span class = "Delimiter" > ))< / span >
< span id = "L453" class = "LineNr" > 453 < / span > < a href = '003trace.cc.html#L226' > raise< / a > < < < span class = "Constant" > " '" < / span > < < to_string< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > )< / span > < < < span class = "Constant" > " '" < / span > < < < a href = '033check_operands.cc.html#L293' > maybe_name< / a > < span class = "Delimiter" > (< / span > op< span class = "Delimiter" > )< / span > < < < span class = "Constant" > " : unexpected " < / span > < < type < < < span class = "Constant" > " argument (" < / span > < < msg < < < span class = "Constant" > " )\n" < / span > < < end< span class = "Delimiter" > ();< / span >
< span id = "L454" class = "LineNr" > 454 < / span > < span class = "Delimiter" > }< / span >
< span id = "L455" class = "LineNr" > 455 < / span >
< span id = "L456" class = "LineNr" > 456 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L456' > test_modrm_with_displacement< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
< span id = "L457" class = "LineNr" > 457 < / span > < span class = "SpecialChar" > < a href = '010vm.cc.html#L25' > Reg< / a > < / span > [EAX]< span class = "Delimiter" > .< / span > u = < span class = "Constant" > 0x1< / span > < span class = "Delimiter" > ;< / span >
< span id = "L458" class = "LineNr" > 458 < / span > transform< span class = "Delimiter" > (< / span >
< span id = "L459" class = "LineNr" > 459 < / span > < span class = "Constant" > " == code 0x1\n" < / span >
< span id = "L460" class = "LineNr" > 460 < / span > < span class = "Comment" > // just avoid null pointer< / span >
< span id = "L461" class = "LineNr" > 461 < / span > < span class = "Constant" > " 8b/copy 1/mod/lookup+disp8 0/rm32/EAX 2/r32/EDX 4/disp8\n" < / span > < span class = "Comment" > // copy *(EAX+4) to EDX< / span >
2020-03-07 02:39:16 +00:00
< span id = "L462" class = "LineNr" > 462 < / span > < span class = "Delimiter" > );< / span >
2020-10-05 18:00:05 +00:00
< span id = "L463" class = "LineNr" > 463 < / span > < a href = '003trace.cc.html#L294' > CHECK_TRACE_COUNT< / a > < span class = "Delimiter" > (< / span > < span class = "Constant" > " error" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0< / span > < span class = "Delimiter" > );< / span >
< span id = "L464" class = "LineNr" > 464 < / span > < span class = "Delimiter" > }< / span >
< span id = "L465" class = "LineNr" > 465 < / span >
< span id = "L466" class = "LineNr" > 466 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L466' > test_check_missing_disp8< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
< span id = "L467" class = "LineNr" > 467 < / span > < span class = "SpecialChar" > Hide_errors< / span > = < span class = "Constant" > true< / span > < span class = "Delimiter" > ;< / span >
< span id = "L468" class = "LineNr" > 468 < / span > transform< span class = "Delimiter" > (< / span >
< span id = "L469" class = "LineNr" > 469 < / span > < span class = "Constant" > " == code 0x1\n" < / span >
< span id = "L470" class = "LineNr" > 470 < / span > < span class = "Constant" > " 89/copy 1/mod/lookup+disp8 0/rm32/EAX 1/r32/ECX\n" < / span > < span class = "Comment" > // missing disp8< / span >
< span id = "L471" class = "LineNr" > 471 < / span > < span class = "Delimiter" > );< / span >
< span id = "L472" class = "LineNr" > 472 < / span > < a href = '003trace.cc.html#L290' > CHECK_TRACE_CONTENTS< / a > < span class = "Delimiter" > (< / span >
< span id = "L473" class = "LineNr" > 473 < / span > < span class = "Constant" > " error: '89/copy 1/mod/lookup+disp8 0/rm32/EAX 1/r32/ECX' (copy r32 to rm32): missing disp8 argument\n" < / span >
< span id = "L474" class = "LineNr" > 474 < / span > < span class = "Delimiter" > );< / span >
< span id = "L475" class = "LineNr" > 475 < / span > < span class = "Delimiter" > }< / span >
< span id = "L476" class = "LineNr" > 476 < / span >
< span id = "L477" class = "LineNr" > 477 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L477' > test_check_missing_disp32< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
< span id = "L478" class = "LineNr" > 478 < / span > < span class = "SpecialChar" > Hide_errors< / span > = < span class = "Constant" > true< / span > < span class = "Delimiter" > ;< / span >
< span id = "L479" class = "LineNr" > 479 < / span > transform< span class = "Delimiter" > (< / span >
< span id = "L480" class = "LineNr" > 480 < / span > < span class = "Constant" > " == code 0x1\n" < / span >
< span id = "L481" class = "LineNr" > 481 < / span > < span class = "Constant" > " 8b/copy 0/mod/indirect 5/rm32/.disp32 2/r32/EDX\n" < / span > < span class = "Comment" > // missing disp32< / span >
< span id = "L482" class = "LineNr" > 482 < / span > < span class = "Delimiter" > );< / span >
< span id = "L483" class = "LineNr" > 483 < / span > < a href = '003trace.cc.html#L290' > CHECK_TRACE_CONTENTS< / a > < span class = "Delimiter" > (< / span >
< span id = "L484" class = "LineNr" > 484 < / span > < span class = "Constant" > " error: '8b/copy 0/mod/indirect 5/rm32/.disp32 2/r32/EDX' (copy rm32 to r32): missing < a href = '040tests.cc.html#L82' > disp32< / a > argument\n" < / span >
< span id = "L485" class = "LineNr" > 485 < / span > < span class = "Delimiter" > );< / span >
< span id = "L486" class = "LineNr" > 486 < / span > < span class = "Delimiter" > }< / span >
< span id = "L487" class = "LineNr" > 487 < / span >
< span id = "L488" class = "LineNr" > 488 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L488' > test_conflicting_arguments_in_modrm_instruction< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
< span id = "L489" class = "LineNr" > 489 < / span > < span class = "SpecialChar" > Hide_errors< / span > = < span class = "Constant" > true< / span > < span class = "Delimiter" > ;< / span >
< span id = "L490" class = "LineNr" > 490 < / span > < a href = '011run.cc.html#L82' > run< / a > < span class = "Delimiter" > (< / span >
< span id = "L491" class = "LineNr" > 491 < / span > < span class = "Constant" > " == code 0x1\n" < / span >
< span id = "L492" class = "LineNr" > 492 < / span > < span class = "Constant" > " 01/add 0/mod 3/mod\n" < / span >
< span id = "L493" class = "LineNr" > 493 < / span > < span class = "Delimiter" > );< / span >
< span id = "L494" class = "LineNr" > 494 < / span > < a href = '003trace.cc.html#L290' > CHECK_TRACE_CONTENTS< / a > < span class = "Delimiter" > (< / span >
< span id = "L495" class = "LineNr" > 495 < / span > < span class = "Constant" > " error: '01/add 0/mod 3/mod' has conflicting mod arguments\n" < / span >
< span id = "L496" class = "LineNr" > 496 < / span > < span class = "Delimiter" > );< / span >
< span id = "L497" class = "LineNr" > 497 < / span > < span class = "Delimiter" > }< / span >
< span id = "L498" class = "LineNr" > 498 < / span >
< span id = "L499" class = "LineNr" > 499 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L499' > test_conflicting_argument_type_modrm< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
< span id = "L500" class = "LineNr" > 500 < / span > < span class = "SpecialChar" > Hide_errors< / span > = < span class = "Constant" > true< / span > < span class = "Delimiter" > ;< / span >
< span id = "L501" class = "LineNr" > 501 < / span > < a href = '011run.cc.html#L82' > run< / a > < span class = "Delimiter" > (< / span >
< span id = "L502" class = "LineNr" > 502 < / span > < span class = "Constant" > " == code 0x1\n" < / span >
< span id = "L503" class = "LineNr" > 503 < / span > < span class = "Constant" > " 01/add 0/mod 3/rm32/r32\n" < / span >
< span id = "L504" class = "LineNr" > 504 < / span > < span class = "Delimiter" > );< / span >
< span id = "L505" class = "LineNr" > 505 < / span > < a href = '003trace.cc.html#L290' > CHECK_TRACE_CONTENTS< / a > < span class = "Delimiter" > (< / span >
< span id = "L506" class = "LineNr" > 506 < / span > < span class = "Constant" > " error: '3/rm32/r32' has conflicting argument types; it should have only one\n" < / span >
< span id = "L507" class = "LineNr" > 507 < / span > < span class = "Delimiter" > );< / span >
< span id = "L508" class = "LineNr" > 508 < / span > < span class = "Delimiter" > }< / span >
< span id = "L509" class = "LineNr" > 509 < / span >
< span id = "L510" class = "LineNr" > 510 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L510' > test_check_missing_rm32_argument< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
< span id = "L511" class = "LineNr" > 511 < / span > < span class = "SpecialChar" > Hide_errors< / span > = < span class = "Constant" > true< / span > < span class = "Delimiter" > ;< / span >
< span id = "L512" class = "LineNr" > 512 < / span > < a href = '011run.cc.html#L82' > run< / a > < span class = "Delimiter" > (< / span >
< span id = "L513" class = "LineNr" > 513 < / span > < span class = "Constant" > " == code 0x1\n" < / span >
< span id = "L514" class = "LineNr" > 514 < / span > < span class = "Constant" > " 81 0/add/subop 0/mod 1/imm32\n" < / span >
< span id = "L515" class = "LineNr" > 515 < / span > < span class = "Delimiter" > );< / span >
< span id = "L516" class = "LineNr" > 516 < / span > < a href = '003trace.cc.html#L290' > CHECK_TRACE_CONTENTS< / a > < span class = "Delimiter" > (< / span >
< span id = "L517" class = "LineNr" > 517 < / span > < span class = "Constant" > " error: '81 0/add/subop 0/mod 1/imm32' (combine rm32 with imm32 based on subop): missing rm32 (or xm32) argument\n" < / span >
< span id = "L518" class = "LineNr" > 518 < / span > < span class = "Delimiter" > );< / span >
< span id = "L519" class = "LineNr" > 519 < / span > < span class = "Delimiter" > }< / span >
< span id = "L520" class = "LineNr" > 520 < / span >
< span id = "L521" class = "LineNr" > 521 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L521' > test_check_missing_subop_argument< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
< span id = "L522" class = "LineNr" > 522 < / span > < span class = "SpecialChar" > Hide_errors< / span > = < span class = "Constant" > true< / span > < span class = "Delimiter" > ;< / span >
< span id = "L523" class = "LineNr" > 523 < / span > < a href = '011run.cc.html#L82' > run< / a > < span class = "Delimiter" > (< / span >
< span id = "L524" class = "LineNr" > 524 < / span > < span class = "Constant" > " == code 0x1\n" < / span >
< span id = "L525" class = "LineNr" > 525 < / span > < span class = "Constant" > " 81 0/mod 3/rm32/ebx 1/imm32\n" < / span >
< span id = "L526" class = "LineNr" > 526 < / span > < span class = "Delimiter" > );< / span >
< span id = "L527" class = "LineNr" > 527 < / span > < a href = '003trace.cc.html#L290' > CHECK_TRACE_CONTENTS< / a > < span class = "Delimiter" > (< / span >
< span id = "L528" class = "LineNr" > 528 < / span > < span class = "Constant" > " error: '81 0/mod 3/rm32/ebx 1/imm32' (combine rm32 with imm32 based on subop): missing subop argument\n" < / span >
< span id = "L529" class = "LineNr" > 529 < / span > < span class = "Delimiter" > );< / span >
< span id = "L530" class = "LineNr" > 530 < / span > < span class = "Delimiter" > }< / span >
< span id = "L531" class = "LineNr" > 531 < / span >
< span id = "L532" class = "LineNr" > 532 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L532' > test_check_missing_base_argument< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
< span id = "L533" class = "LineNr" > 533 < / span > < span class = "SpecialChar" > Hide_errors< / span > = < span class = "Constant" > true< / span > < span class = "Delimiter" > ;< / span >
< span id = "L534" class = "LineNr" > 534 < / span > < a href = '011run.cc.html#L82' > run< / a > < span class = "Delimiter" > (< / span >
< span id = "L535" class = "LineNr" > 535 < / span > < span class = "Constant" > " == code 0x1\n" < / span >
< span id = "L536" class = "LineNr" > 536 < / span > < span class = "Constant" > " 81 0/add/subop 0/mod/indirect 4/rm32/use-sib 1/imm32\n" < / span >
< span id = "L537" class = "LineNr" > 537 < / span > < span class = "Delimiter" > );< / span >
< span id = "L538" class = "LineNr" > 538 < / span > < a href = '003trace.cc.html#L290' > CHECK_TRACE_CONTENTS< / a > < span class = "Delimiter" > (< / span >
< span id = "L539" class = "LineNr" > 539 < / span > < span class = "Constant" > " error: '81 0/add/subop 0/mod/indirect 4/rm32/use-sib 1/imm32' (combine rm32 with imm32 based on subop): missing base argument\n" < / span >
< span id = "L540" class = "LineNr" > 540 < / span > < span class = "Delimiter" > );< / span >
< span id = "L541" class = "LineNr" > 541 < / span > < span class = "Delimiter" > }< / span >
< span id = "L542" class = "LineNr" > 542 < / span >
< span id = "L543" class = "LineNr" > 543 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L543' > test_check_missing_index_argument< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
< span id = "L544" class = "LineNr" > 544 < / span > < span class = "SpecialChar" > Hide_errors< / span > = < span class = "Constant" > true< / span > < span class = "Delimiter" > ;< / span >
< span id = "L545" class = "LineNr" > 545 < / span > < a href = '011run.cc.html#L82' > run< / a > < span class = "Delimiter" > (< / span >
< span id = "L546" class = "LineNr" > 546 < / span > < span class = "Constant" > " == code 0x1\n" < / span >
< span id = "L547" class = "LineNr" > 547 < / span > < span class = "Constant" > " 81 0/add/subop 0/mod/indirect 4/rm32/use-sib 0/base 1/imm32\n" < / span >
< span id = "L548" class = "LineNr" > 548 < / span > < span class = "Delimiter" > );< / span >
< span id = "L549" class = "LineNr" > 549 < / span > < a href = '003trace.cc.html#L290' > CHECK_TRACE_CONTENTS< / a > < span class = "Delimiter" > (< / span >
< span id = "L550" class = "LineNr" > 550 < / span > < span class = "Constant" > " error: '81 0/add/subop 0/mod/indirect 4/rm32/use-sib 0/base 1/imm32' (combine rm32 with imm32 based on subop): missing index argument\n" < / span >
< span id = "L551" class = "LineNr" > 551 < / span > < span class = "Delimiter" > );< / span >
< span id = "L552" class = "LineNr" > 552 < / span > < span class = "Delimiter" > }< / span >
< span id = "L553" class = "LineNr" > 553 < / span >
< span id = "L554" class = "LineNr" > 554 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L554' > test_check_missing_base_argument_2< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
< span id = "L555" class = "LineNr" > 555 < / span > < span class = "SpecialChar" > Hide_errors< / span > = < span class = "Constant" > true< / span > < span class = "Delimiter" > ;< / span >
< span id = "L556" class = "LineNr" > 556 < / span > < a href = '011run.cc.html#L82' > run< / a > < span class = "Delimiter" > (< / span >
< span id = "L557" class = "LineNr" > 557 < / span > < span class = "Constant" > " == code 0x1\n" < / span >
< span id = "L558" class = "LineNr" > 558 < / span > < span class = "Constant" > " 81 0/add/subop 0/mod/indirect 4/rm32/use-sib 2/index 3/scale 1/imm32\n" < / span >
< span id = "L559" class = "LineNr" > 559 < / span > < span class = "Delimiter" > );< / span >
< span id = "L560" class = "LineNr" > 560 < / span > < a href = '003trace.cc.html#L290' > CHECK_TRACE_CONTENTS< / a > < span class = "Delimiter" > (< / span >
< span id = "L561" class = "LineNr" > 561 < / span > < span class = "Constant" > " error: '81 0/add/subop 0/mod/indirect 4/rm32/use-sib 2/index 3/scale 1/imm32' (combine rm32 with imm32 based on subop): missing base argument\n" < / span >
< span id = "L562" class = "LineNr" > 562 < / span > < span class = "Delimiter" > );< / span >
< span id = "L563" class = "LineNr" > 563 < / span > < span class = "Delimiter" > }< / span >
< span id = "L564" class = "LineNr" > 564 < / span >
< span id = "L565" class = "LineNr" > 565 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L565' > test_check_extra_displacement< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
< span id = "L566" class = "LineNr" > 566 < / span > < span class = "SpecialChar" > Hide_errors< / span > = < span class = "Constant" > true< / span > < span class = "Delimiter" > ;< / span >
< span id = "L567" class = "LineNr" > 567 < / span > < a href = '011run.cc.html#L82' > run< / a > < span class = "Delimiter" > (< / span >
< span id = "L568" class = "LineNr" > 568 < / span > < span class = "Constant" > " == code 0x1\n" < / span >
< span id = "L569" class = "LineNr" > 569 < / span > < span class = "Constant" > " 89/copy 0/mod/indirect 0/rm32/EAX 1/r32/ECX 4/disp8\n" < / span >
< span id = "L570" class = "LineNr" > 570 < / span > < span class = "Delimiter" > );< / span >
< span id = "L571" class = "LineNr" > 571 < / span > < a href = '003trace.cc.html#L290' > CHECK_TRACE_CONTENTS< / a > < span class = "Delimiter" > (< / span >
< span id = "L572" class = "LineNr" > 572 < / span > < span class = "Constant" > " error: '89/copy 0/mod/indirect 0/rm32/EAX 1/r32/ECX 4/disp8' (copy r32 to rm32): unexpected disp8 argument\n" < / span >
< span id = "L573" class = "LineNr" > 573 < / span > < span class = "Delimiter" > );< / span >
< span id = "L574" class = "LineNr" > 574 < / span > < span class = "Delimiter" > }< / span >
< span id = "L575" class = "LineNr" > 575 < / span >
< span id = "L576" class = "LineNr" > 576 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L576' > test_check_duplicate_argument< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
< span id = "L577" class = "LineNr" > 577 < / span > < span class = "SpecialChar" > Hide_errors< / span > = < span class = "Constant" > true< / span > < span class = "Delimiter" > ;< / span >
< span id = "L578" class = "LineNr" > 578 < / span > < a href = '011run.cc.html#L82' > run< / a > < span class = "Delimiter" > (< / span >
< span id = "L579" class = "LineNr" > 579 < / span > < span class = "Constant" > " == code 0x1\n" < / span >
< span id = "L580" class = "LineNr" > 580 < / span > < span class = "Constant" > " 89/copy 0/mod/indirect 0/rm32/EAX 1/r32/ECX 1/r32\n" < / span >
< span id = "L581" class = "LineNr" > 581 < / span > < span class = "Delimiter" > );< / span >
< span id = "L582" class = "LineNr" > 582 < / span > < a href = '003trace.cc.html#L290' > CHECK_TRACE_CONTENTS< / a > < span class = "Delimiter" > (< / span >
< span id = "L583" class = "LineNr" > 583 < / span > < span class = "Constant" > " error: '89/copy 0/mod/indirect 0/rm32/EAX 1/r32/ECX 1/r32': duplicate r32 argument\n" < / span >
< span id = "L584" class = "LineNr" > 584 < / span > < span class = "Delimiter" > );< / span >
< span id = "L585" class = "LineNr" > 585 < / span > < span class = "Delimiter" > }< / span >
< span id = "L586" class = "LineNr" > 586 < / span >
< span id = "L587" class = "LineNr" > 587 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L587' > test_check_base_argument_not_needed_in_direct_mode< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
2020-03-07 02:39:16 +00:00
< span id = "L588" class = "LineNr" > 588 < / span > < a href = '011run.cc.html#L82' > run< / a > < span class = "Delimiter" > (< / span >
< span id = "L589" class = "LineNr" > 589 < / span > < span class = "Constant" > " == code 0x1\n" < / span >
2020-10-05 18:00:05 +00:00
< span id = "L590" class = "LineNr" > 590 < / span > < span class = "Constant" > " 81 0/add/subop 3/mod/indirect 4/rm32/use-sib 1/imm32\n" < / span >
2020-03-07 02:39:16 +00:00
< span id = "L591" class = "LineNr" > 591 < / span > < span class = "Delimiter" > );< / span >
2020-10-05 18:00:05 +00:00
< span id = "L592" class = "LineNr" > 592 < / span > < a href = '003trace.cc.html#L294' > CHECK_TRACE_COUNT< / a > < span class = "Delimiter" > (< / span > < span class = "Constant" > " error" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0< / span > < span class = "Delimiter" > );< / span >
< span id = "L593" class = "LineNr" > 593 < / span > < span class = "Delimiter" > }< / span >
< span id = "L594" class = "LineNr" > 594 < / span >
< span id = "L595" class = "LineNr" > 595 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L595' > test_extra_modrm< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
< span id = "L596" class = "LineNr" > 596 < / span > < span class = "SpecialChar" > Hide_errors< / span > = < span class = "Constant" > true< / span > < span class = "Delimiter" > ;< / span >
< span id = "L597" class = "LineNr" > 597 < / span > < a href = '011run.cc.html#L82' > run< / a > < span class = "Delimiter" > (< / span >
< span id = "L598" class = "LineNr" > 598 < / span > < span class = "Constant" > " == code 0x1\n" < / span >
< span id = "L599" class = "LineNr" > 599 < / span > < span class = "Constant" > " 59/pop-to-ECX 3/mod/direct 1/rm32/ECX 4/r32/ESP\n" < / span >
< span id = "L600" class = "LineNr" > 600 < / span > < span class = "Delimiter" > );< / span >
< span id = "L601" class = "LineNr" > 601 < / span > < a href = '003trace.cc.html#L290' > CHECK_TRACE_CONTENTS< / a > < span class = "Delimiter" > (< / span >
< span id = "L602" class = "LineNr" > 602 < / span > < span class = "Constant" > " error: '59/pop-to-ECX 3/mod/direct 1/rm32/ECX 4/r32/ESP' (< a href = '013direct_addressing.cc.html#L1270' > pop< / a > top of stack to < a href = '010vm.cc.html#L11' > ECX< / a > ): unexpected modrm argument\n" < / span >
< span id = "L603" class = "LineNr" > 603 < / span > < span class = "Delimiter" > );< / span >
< span id = "L604" class = "LineNr" > 604 < / span > < span class = "Delimiter" > }< / span >
< span id = "L605" class = "LineNr" > 605 < / span >
< span id = "L606" class = "LineNr" > 606 < / span > < span class = "SalientComment" > //:: similarly handle multi-byte opcodes< / span >
< span id = "L607" class = "LineNr" > 607 < / span >
< span id = "L608" class = "LineNr" > 608 < / span > < span class = "Normal" > void< / span > check_arguments_0f< span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > line& inst< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L609" class = "LineNr" > 609 < / span > assert< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > .< / span > < a href = '011run.cc.html#L122' > words< / a > < span class = "Delimiter" > .< / span > at< span class = "Delimiter" > (< / span > < span class = "Constant" > 0< / span > < span class = "Delimiter" > ).< / span > data == < span class = "Constant" > " 0f" < / span > < span class = "Delimiter" > );< / span >
< span id = "L610" class = "LineNr" > 610 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > < a href = '001help.cc.html#L166' > SIZE< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > .< / span > < a href = '011run.cc.html#L122' > words< / a > < span class = "Delimiter" > )< / span > == < span class = "Constant" > 1< / span > < span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L611" class = "LineNr" > 611 < / span > < a href = '003trace.cc.html#L226' > raise< / a > < < < span class = "Constant" > " opcode '0f' requires a second opcode\n" < / span > < < end< span class = "Delimiter" > ();< / span >
< span id = "L612" class = "LineNr" > 612 < / span > < span class = "Identifier" > return< / span > < span class = "Delimiter" > ;< / span >
< span id = "L613" class = "LineNr" > 613 < / span > < span class = "Delimiter" > }< / span >
< span id = "L614" class = "LineNr" > 614 < / span > < a href = '011run.cc.html#L127' > word< / a > op = < a href = '033check_operands.cc.html#L41' > preprocess_op< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > .< / span > < a href = '011run.cc.html#L122' > words< / a > < span class = "Delimiter" > .< / span > at< span class = "Delimiter" > (< / span > < span class = "Constant" > 1< / span > < span class = "Delimiter" > ));< / span >
< span id = "L615" class = "LineNr" > 615 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > !contains_key< span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '010vm.cc.html#L356' > Name_0f< / a > < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > .< / span > data< span class = "Delimiter" > ))< / span > < span class = "Delimiter" > {< / span >
< span id = "L616" class = "LineNr" > 616 < / span > < a href = '003trace.cc.html#L226' > raise< / a > < < < span class = "Constant" > " unknown 2-byte opcode '0f " < / span > < < op< span class = "Delimiter" > .< / span > data < < < span class = "Constant" > " '\n" < / span > < < end< span class = "Delimiter" > ();< / span >
< span id = "L617" class = "LineNr" > 617 < / span > < span class = "Identifier" > return< / span > < span class = "Delimiter" > ;< / span >
< span id = "L618" class = "LineNr" > 618 < / span > < span class = "Delimiter" > }< / span >
< span id = "L619" class = "LineNr" > 619 < / span > check_arguments_0f< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > );< / span >
< span id = "L620" class = "LineNr" > 620 < / span > < span class = "Delimiter" > }< / span >
< span id = "L621" class = "LineNr" > 621 < / span >
< span id = "L622" class = "LineNr" > 622 < / span > < span class = "Normal" > void< / span > check_arguments_f3< span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > line& inst< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L623" class = "LineNr" > 623 < / span > assert< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > .< / span > < a href = '011run.cc.html#L122' > words< / a > < span class = "Delimiter" > .< / span > at< span class = "Delimiter" > (< / span > < span class = "Constant" > 0< / span > < span class = "Delimiter" > ).< / span > data == < span class = "Constant" > " f3" < / span > < span class = "Delimiter" > );< / span >
< span id = "L624" class = "LineNr" > 624 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > < a href = '001help.cc.html#L166' > SIZE< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > .< / span > < a href = '011run.cc.html#L122' > words< / a > < span class = "Delimiter" > )< / span > == < span class = "Constant" > 1< / span > < span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L625" class = "LineNr" > 625 < / span > < a href = '003trace.cc.html#L226' > raise< / a > < < < span class = "Constant" > " opcode 'f3' requires a second opcode\n" < / span > < < end< span class = "Delimiter" > ();< / span >
< span id = "L626" class = "LineNr" > 626 < / span > < span class = "Identifier" > return< / span > < span class = "Delimiter" > ;< / span >
< span id = "L627" class = "LineNr" > 627 < / span > < span class = "Delimiter" > }< / span >
< span id = "L628" class = "LineNr" > 628 < / span > < a href = '011run.cc.html#L127' > word< / a > op = < a href = '033check_operands.cc.html#L41' > preprocess_op< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > .< / span > < a href = '011run.cc.html#L122' > words< / a > < span class = "Delimiter" > .< / span > at< span class = "Delimiter" > (< / span > < span class = "Constant" > 1< / span > < span class = "Delimiter" > ));< / span >
< span id = "L629" class = "LineNr" > 629 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > op< span class = "Delimiter" > .< / span > data == < span class = "Constant" > " 0f" < / span > < span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L630" class = "LineNr" > 630 < / span > < a href = '011run.cc.html#L127' > word< / a > op2 = < a href = '033check_operands.cc.html#L41' > preprocess_op< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > .< / span > < a href = '011run.cc.html#L122' > words< / a > < span class = "Delimiter" > .< / span > at< span class = "Delimiter" > (< / span > < span class = "Constant" > 2< / span > < span class = "Delimiter" > ));< / span >
< span id = "L631" class = "LineNr" > 631 < / span > < a href = '033check_operands.cc.html#L739' > check_arguments_f3_0f< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > op2< span class = "Delimiter" > );< / span >
< span id = "L632" class = "LineNr" > 632 < / span > < span class = "Identifier" > return< / span > < span class = "Delimiter" > ;< / span >
< span id = "L633" class = "LineNr" > 633 < / span > < span class = "Delimiter" > }< / span >
< span id = "L634" class = "LineNr" > 634 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > !contains_key< span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '010vm.cc.html#L357' > Name_f3< / a > < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > .< / span > data< span class = "Delimiter" > ))< / span > < span class = "Delimiter" > {< / span >
< span id = "L635" class = "LineNr" > 635 < / span > < a href = '003trace.cc.html#L226' > raise< / a > < < < span class = "Constant" > " unknown 2-byte opcode 'f3 " < / span > < < op< span class = "Delimiter" > .< / span > data < < < span class = "Constant" > " '\n" < / span > < < end< span class = "Delimiter" > ();< / span >
< span id = "L636" class = "LineNr" > 636 < / span > < span class = "Identifier" > return< / span > < span class = "Delimiter" > ;< / span >
< span id = "L637" class = "LineNr" > 637 < / span > < span class = "Delimiter" > }< / span >
< span id = "L638" class = "LineNr" > 638 < / span > check_arguments_f3< span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > );< / span >
< span id = "L639" class = "LineNr" > 639 < / span > < span class = "Delimiter" > }< / span >
< span id = "L640" class = "LineNr" > 640 < / span >
< span id = "L641" class = "LineNr" > 641 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L641' > test_check_missing_disp32_argument< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
< span id = "L642" class = "LineNr" > 642 < / span > < span class = "SpecialChar" > Hide_errors< / span > = < span class = "Constant" > true< / span > < span class = "Delimiter" > ;< / span >
< span id = "L643" class = "LineNr" > 643 < / span > < a href = '011run.cc.html#L82' > run< / a > < span class = "Delimiter" > (< / span >
< span id = "L644" class = "LineNr" > 644 < / span > < span class = "Constant" > " == code 0x1\n" < / span >
< span id = "L645" class = "LineNr" > 645 < / span > < span class = "Constant" > " 0f 84 # jmp if ZF to ??\n" < / span >
< span id = "L646" class = "LineNr" > 646 < / span > < span class = "Delimiter" > );< / span >
< span id = "L647" class = "LineNr" > 647 < / span > < a href = '003trace.cc.html#L290' > CHECK_TRACE_CONTENTS< / a > < span class = "Delimiter" > (< / span >
< span id = "L648" class = "LineNr" > 648 < / span > < span class = "Constant" > " error: '0f 84' (jump < a href = '040tests.cc.html#L82' > disp32< / a > bytes away if equal, if < a href = '010vm.cc.html#L89' > ZF< / a > is set): missing < a href = '040tests.cc.html#L82' > disp32< / a > argument\n" < / span >
< span id = "L649" class = "LineNr" > 649 < / span > < span class = "Delimiter" > );< / span >
< span id = "L650" class = "LineNr" > 650 < / span > < span class = "Delimiter" > }< / span >
< span id = "L651" class = "LineNr" > 651 < / span >
< span id = "L652" class = "LineNr" > 652 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L652' > test_0f_opcode_with_modrm< / a > < span class = "Delimiter" > ()< / span > < span class = "Delimiter" > {< / span >
< span id = "L653" class = "LineNr" > 653 < / span > transform< span class = "Delimiter" > (< / span >
< span id = "L654" class = "LineNr" > 654 < / span > < span class = "Constant" > " == code 0x1\n" < / span >
< span id = "L655" class = "LineNr" > 655 < / span > < span class = "Constant" > " 0f af/multiply 2/mod/*+disp32 5/rm32/ebp 8/disp32 0/r32\n" < / span >
< span id = "L656" class = "LineNr" > 656 < / span > < span class = "Delimiter" > );< / span >
< span id = "L657" class = "LineNr" > 657 < / span > < a href = '003trace.cc.html#L304' > CHECK_TRACE_DOESNT_CONTAIN_ERRORS< / a > < span class = "Delimiter" > ();< / span >
< span id = "L658" class = "LineNr" > 658 < / span > < span class = "Delimiter" > }< / span >
< span id = "L659" class = "LineNr" > 659 < / span >
< span id = "L660" class = "LineNr" > 660 < / span > < span class = "Delimiter" > :(before " End Globals" )< / span >
< span id = "L661" class = "LineNr" > 661 < / span > map< < span class = "Comment" > /*< / span > < span class = "Comment" > op< / span > < span class = "Comment" > */< / span > string< span class = "Delimiter" > ,< / span > < span class = "Comment" > /*< / span > < span class = "Comment" > bitvector< / span > < span class = "Comment" > */< / span > < span class = "Normal" > uint8_t< / span > > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ;< / span >
< span id = "L662" class = "LineNr" > 662 < / span > < span class = "Delimiter" > :(before " End Init Permitted Operands" )< / span >
< span id = "L663" class = "LineNr" > 663 < / span > < span class = "SalientComment" > //// Class D: just op and disp32< / span >
< span id = "L664" class = "LineNr" > 664 < / span > < span class = "Comment" > // imm32 imm8 disp32 |disp16 disp8 subop modrm< / span >
< span id = "L665" class = "LineNr" > 665 < / span > < span class = "Comment" > // 0 0 1 |0 0 0 0< / span >
< span id = "L666" class = "LineNr" > 666 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 82" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x10< / span > < span class = "Delimiter" > );< / span >
< span id = "L667" class = "LineNr" > 667 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 83" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x10< / span > < span class = "Delimiter" > );< / span >
< span id = "L668" class = "LineNr" > 668 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 84" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x10< / span > < span class = "Delimiter" > );< / span >
< span id = "L669" class = "LineNr" > 669 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 85" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x10< / span > < span class = "Delimiter" > );< / span >
< span id = "L670" class = "LineNr" > 670 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 86" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x10< / span > < span class = "Delimiter" > );< / span >
< span id = "L671" class = "LineNr" > 671 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 87" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x10< / span > < span class = "Delimiter" > );< / span >
< span id = "L672" class = "LineNr" > 672 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 8c" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x10< / span > < span class = "Delimiter" > );< / span >
< span id = "L673" class = "LineNr" > 673 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 8d" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x10< / span > < span class = "Delimiter" > );< / span >
< span id = "L674" class = "LineNr" > 674 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 8e" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x10< / span > < span class = "Delimiter" > );< / span >
< span id = "L675" class = "LineNr" > 675 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 8f" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x10< / span > < span class = "Delimiter" > );< / span >
< span id = "L676" class = "LineNr" > 676 < / span >
< span id = "L677" class = "LineNr" > 677 < / span > < span class = "SalientComment" > //// Class M: using ModR/M byte< / span >
< span id = "L678" class = "LineNr" > 678 < / span > < span class = "Comment" > // imm32 imm8 disp32 |disp16 disp8 subop modrm< / span >
< span id = "L679" class = "LineNr" > 679 < / span > < span class = "Comment" > // 0 0 0 |0 0 0 1< / span >
< span id = "L680" class = "LineNr" > 680 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 2f" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // compare floats< / span >
< span id = "L681" class = "LineNr" > 681 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " af" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // multiply ints< / span >
< span id = "L682" class = "LineNr" > 682 < / span > < span class = "Comment" > // setcc< / span >
< span id = "L683" class = "LineNr" > 683 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 92" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
< span id = "L684" class = "LineNr" > 684 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 93" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
< span id = "L685" class = "LineNr" > 685 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 94" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
< span id = "L686" class = "LineNr" > 686 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 95" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
< span id = "L687" class = "LineNr" > 687 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 96" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
< span id = "L688" class = "LineNr" > 688 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 97" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
< span id = "L689" class = "LineNr" > 689 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 9c" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
< span id = "L690" class = "LineNr" > 690 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 9d" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
< span id = "L691" class = "LineNr" > 691 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 9e" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
< span id = "L692" class = "LineNr" > 692 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 9f" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span >
< span id = "L693" class = "LineNr" > 693 < / span >
< span id = "L694" class = "LineNr" > 694 < / span > < span class = "Delimiter" > :(before " End Globals" )< / span >
< span id = "L695" class = "LineNr" > 695 < / span > map< < span class = "Comment" > /*< / span > < span class = "Comment" > op< / span > < span class = "Comment" > */< / span > string< span class = "Delimiter" > ,< / span > < span class = "Comment" > /*< / span > < span class = "Comment" > bitvector< / span > < span class = "Comment" > */< / span > < span class = "Normal" > uint8_t< / span > > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L695' > Permitted_arguments_f3< / a > < / span > < span class = "Delimiter" > ;< / span >
< span id = "L696" class = "LineNr" > 696 < / span > map< < span class = "Comment" > /*< / span > < span class = "Comment" > op< / span > < span class = "Comment" > */< / span > string< span class = "Delimiter" > ,< / span > < span class = "Comment" > /*< / span > < span class = "Comment" > bitvector< / span > < span class = "Comment" > */< / span > < span class = "Normal" > uint8_t< / span > > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L696' > Permitted_arguments_f3_0f< / a > < / span > < span class = "Delimiter" > ;< / span >
< span id = "L697" class = "LineNr" > 697 < / span > < span class = "Delimiter" > :(before " End Init Permitted Operands" )< / span >
< span id = "L698" class = "LineNr" > 698 < / span > < span class = "SalientComment" > //// Class M: using ModR/M byte< / span >
< span id = "L699" class = "LineNr" > 699 < / span > < span class = "Comment" > // imm32 imm8 disp32 |disp16 disp8 subop modrm< / span >
< span id = "L700" class = "LineNr" > 700 < / span > < span class = "Comment" > // 0 0 0 |0 0 0 1< / span >
< span id = "L701" class = "LineNr" > 701 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L696' > Permitted_arguments_f3_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 10" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // copy xm32 to x32< / span >
< span id = "L702" class = "LineNr" > 702 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L696' > Permitted_arguments_f3_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 11" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // copy x32 to xm32< / span >
< span id = "L703" class = "LineNr" > 703 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L696' > Permitted_arguments_f3_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 2a" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // convert-to-float< / span >
< span id = "L704" class = "LineNr" > 704 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L696' > Permitted_arguments_f3_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 2c" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // truncate-to-int< / span >
< span id = "L705" class = "LineNr" > 705 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L696' > Permitted_arguments_f3_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 2d" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // convert-to-int< / span >
< span id = "L706" class = "LineNr" > 706 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L696' > Permitted_arguments_f3_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 51" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // square root< / span >
< span id = "L707" class = "LineNr" > 707 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L696' > Permitted_arguments_f3_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 52" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // inverse square root< / span >
< span id = "L708" class = "LineNr" > 708 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L696' > Permitted_arguments_f3_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 53" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // reciprocal< / span >
< span id = "L709" class = "LineNr" > 709 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L696' > Permitted_arguments_f3_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 58" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // add floats< / span >
< span id = "L710" class = "LineNr" > 710 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L696' > Permitted_arguments_f3_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 59" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // multiply floats< / span >
< span id = "L711" class = "LineNr" > 711 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L696' > Permitted_arguments_f3_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 5c" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // subtract floats< / span >
< span id = "L712" class = "LineNr" > 712 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L696' > Permitted_arguments_f3_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 5d" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // minimum of floats< / span >
< span id = "L713" class = "LineNr" > 713 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L696' > Permitted_arguments_f3_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 5e" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // divide floats< / span >
< span id = "L714" class = "LineNr" > 714 < / span > < a href = '001help.cc.html#L235' > put_new< / a > < span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L696' > Permitted_arguments_f3_0f< / a > < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > " 5f" < / span > < span class = "Delimiter" > ,< / span > < span class = "Constant" > 0x01< / span > < span class = "Delimiter" > );< / span > < span class = "Comment" > // maximum of floats< / span >
< span id = "L715" class = "LineNr" > 715 < / span >
< span id = "L716" class = "LineNr" > 716 < / span > < span class = "Delimiter" > :(code)< / span >
< span id = "L717" class = "LineNr" > 717 < / span > < span class = "Normal" > void< / span > check_arguments_0f< span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > line& inst< span class = "Delimiter" > ,< / span > < span class = "Normal" > const< / span > word& op< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L718" class = "LineNr" > 718 < / span > < span class = "Normal" > uint8_t< / span > expected_bitvector = get< span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L661' > Permitted_arguments_0f< / a > < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > .< / span > data< span class = "Delimiter" > );< / span >
< span id = "L719" class = "LineNr" > 719 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > HAS< span class = "Delimiter" > (< / span > expected_bitvector< span class = "Delimiter" > ,< / span > < a href = '033check_operands.cc.html#L69' > MODRM< / a > < span class = "Delimiter" > ))< / span > < span class = "Delimiter" > {< / span >
< span id = "L720" class = "LineNr" > 720 < / span > < a href = '033check_operands.cc.html#L377' > check_arguments_modrm< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > );< / span >
< span id = "L721" class = "LineNr" > 721 < / span > < a href = '033check_operands.cc.html#L412' > compare_bitvector_modrm< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > expected_bitvector< span class = "Delimiter" > ,< / span > < a href = '033check_operands.cc.html#L750' > maybe_name_0f< / a > < span class = "Delimiter" > (< / span > op< span class = "Delimiter" > ));< / span >
< span id = "L722" class = "LineNr" > 722 < / span > < span class = "Delimiter" > }< / span >
< span id = "L723" class = "LineNr" > 723 < / span > < span class = "Normal" > else< / span > < span class = "Delimiter" > {< / span >
< span id = "L724" class = "LineNr" > 724 < / span > < a href = '033check_operands.cc.html#L275' > compare_bitvector< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > CLEAR< span class = "Delimiter" > (< / span > expected_bitvector< span class = "Delimiter" > ,< / span > < a href = '033check_operands.cc.html#L69' > MODRM< / a > < span class = "Delimiter" > ),< / span > < a href = '033check_operands.cc.html#L750' > maybe_name_0f< / a > < span class = "Delimiter" > (< / span > op< span class = "Delimiter" > ));< / span >
< span id = "L725" class = "LineNr" > 725 < / span > < span class = "Delimiter" > }< / span >
< span id = "L726" class = "LineNr" > 726 < / span > < span class = "Delimiter" > }< / span >
< span id = "L727" class = "LineNr" > 727 < / span >
< span id = "L728" class = "LineNr" > 728 < / span > < span class = "Normal" > void< / span > check_arguments_f3< span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > line& inst< span class = "Delimiter" > ,< / span > < span class = "Normal" > const< / span > word& op< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L729" class = "LineNr" > 729 < / span > < span class = "Normal" > uint8_t< / span > expected_bitvector = get< span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L695' > Permitted_arguments_f3< / a > < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > .< / span > data< span class = "Delimiter" > );< / span >
< span id = "L730" class = "LineNr" > 730 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > HAS< span class = "Delimiter" > (< / span > expected_bitvector< span class = "Delimiter" > ,< / span > < a href = '033check_operands.cc.html#L69' > MODRM< / a > < span class = "Delimiter" > ))< / span > < span class = "Delimiter" > {< / span >
< span id = "L731" class = "LineNr" > 731 < / span > < a href = '033check_operands.cc.html#L377' > check_arguments_modrm< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > );< / span >
< span id = "L732" class = "LineNr" > 732 < / span > < a href = '033check_operands.cc.html#L412' > compare_bitvector_modrm< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > expected_bitvector< span class = "Delimiter" > ,< / span > < a href = '033check_operands.cc.html#L758' > maybe_name_f3< / a > < span class = "Delimiter" > (< / span > op< span class = "Delimiter" > ));< / span >
< span id = "L733" class = "LineNr" > 733 < / span > < span class = "Delimiter" > }< / span >
< span id = "L734" class = "LineNr" > 734 < / span > < span class = "Normal" > else< / span > < span class = "Delimiter" > {< / span >
< span id = "L735" class = "LineNr" > 735 < / span > < a href = '033check_operands.cc.html#L275' > compare_bitvector< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > CLEAR< span class = "Delimiter" > (< / span > expected_bitvector< span class = "Delimiter" > ,< / span > < a href = '033check_operands.cc.html#L69' > MODRM< / a > < span class = "Delimiter" > ),< / span > < a href = '033check_operands.cc.html#L758' > maybe_name_f3< / a > < span class = "Delimiter" > (< / span > op< span class = "Delimiter" > ));< / span >
< span id = "L736" class = "LineNr" > 736 < / span > < span class = "Delimiter" > }< / span >
< span id = "L737" class = "LineNr" > 737 < / span > < span class = "Delimiter" > }< / span >
< span id = "L738" class = "LineNr" > 738 < / span >
< span id = "L739" class = "LineNr" > 739 < / span > < span class = "Normal" > void< / span > < a href = '033check_operands.cc.html#L739' > check_arguments_f3_0f< / a > < span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > line& inst< span class = "Delimiter" > ,< / span > < span class = "Normal" > const< / span > word& op< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L740" class = "LineNr" > 740 < / span > < span class = "Normal" > uint8_t< / span > expected_bitvector = get< span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '033check_operands.cc.html#L696' > Permitted_arguments_f3_0f< / a > < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > .< / span > data< span class = "Delimiter" > );< / span >
< span id = "L741" class = "LineNr" > 741 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > HAS< span class = "Delimiter" > (< / span > expected_bitvector< span class = "Delimiter" > ,< / span > < a href = '033check_operands.cc.html#L69' > MODRM< / a > < span class = "Delimiter" > ))< / span > < span class = "Delimiter" > {< / span >
< span id = "L742" class = "LineNr" > 742 < / span > < a href = '033check_operands.cc.html#L377' > check_arguments_modrm< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > );< / span >
< span id = "L743" class = "LineNr" > 743 < / span > < a href = '033check_operands.cc.html#L412' > compare_bitvector_modrm< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > expected_bitvector< span class = "Delimiter" > ,< / span > < a href = '033check_operands.cc.html#L766' > maybe_name_f3_0f< / a > < span class = "Delimiter" > (< / span > op< span class = "Delimiter" > ));< / span >
< span id = "L744" class = "LineNr" > 744 < / span > < span class = "Delimiter" > }< / span >
< span id = "L745" class = "LineNr" > 745 < / span > < span class = "Normal" > else< / span > < span class = "Delimiter" > {< / span >
< span id = "L746" class = "LineNr" > 746 < / span > < a href = '033check_operands.cc.html#L275' > compare_bitvector< / a > < span class = "Delimiter" > (< / span > inst< span class = "Delimiter" > ,< / span > CLEAR< span class = "Delimiter" > (< / span > expected_bitvector< span class = "Delimiter" > ,< / span > < a href = '033check_operands.cc.html#L69' > MODRM< / a > < span class = "Delimiter" > ),< / span > < a href = '033check_operands.cc.html#L766' > maybe_name_f3_0f< / a > < span class = "Delimiter" > (< / span > op< span class = "Delimiter" > ));< / span >
< span id = "L747" class = "LineNr" > 747 < / span > < span class = "Delimiter" > }< / span >
< span id = "L748" class = "LineNr" > 748 < / span > < span class = "Delimiter" > }< / span >
< span id = "L749" class = "LineNr" > 749 < / span >
< span id = "L750" class = "LineNr" > 750 < / span > string < a href = '033check_operands.cc.html#L750' > maybe_name_0f< / a > < span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > word& op< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L751" class = "LineNr" > 751 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > !is_hex_byte< span class = "Delimiter" > (< / span > op< span class = "Delimiter" > ))< / span > < span class = "Identifier" > return< / span > < span class = "Constant" > " " < / span > < span class = "Delimiter" > ;< / span >
< span id = "L752" class = "LineNr" > 752 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > !contains_key< span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '010vm.cc.html#L356' > Name_0f< / a > < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > .< / span > data< span class = "Delimiter" > ))< / span > < span class = "Identifier" > return< / span > < span class = "Constant" > " " < / span > < span class = "Delimiter" > ;< / span >
< span id = "L753" class = "LineNr" > 753 < / span > < span class = "Comment" > // strip stuff in parens from the name< / span >
< span id = "L754" class = "LineNr" > 754 < / span > < span class = "Normal" > const< / span > string& s = get< span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '010vm.cc.html#L356' > Name_0f< / a > < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > .< / span > data< span class = "Delimiter" > );< / span >
< span id = "L755" class = "LineNr" > 755 < / span > < span class = "Identifier" > return< / span > < span class = "Constant" > " (" < / span > +s< span class = "Delimiter" > .< / span > substr< span class = "Delimiter" > (< / span > < span class = "Constant" > 0< / span > < span class = "Delimiter" > ,< / span > s< span class = "Delimiter" > .< / span > find< span class = "Delimiter" > (< / span > < span class = "Constant" > " (" < / span > < span class = "Delimiter" > ))< / span > +< span class = "Constant" > ')'< / span > < span class = "Delimiter" > ;< / span >
< span id = "L756" class = "LineNr" > 756 < / span > < span class = "Delimiter" > }< / span >
< span id = "L757" class = "LineNr" > 757 < / span >
< span id = "L758" class = "LineNr" > 758 < / span > string < a href = '033check_operands.cc.html#L758' > maybe_name_f3< / a > < span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > word& op< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L759" class = "LineNr" > 759 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > !is_hex_byte< span class = "Delimiter" > (< / span > op< span class = "Delimiter" > ))< / span > < span class = "Identifier" > return< / span > < span class = "Constant" > " " < / span > < span class = "Delimiter" > ;< / span >
< span id = "L760" class = "LineNr" > 760 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > !contains_key< span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '010vm.cc.html#L357' > Name_f3< / a > < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > .< / span > data< span class = "Delimiter" > ))< / span > < span class = "Identifier" > return< / span > < span class = "Constant" > " " < / span > < span class = "Delimiter" > ;< / span >
< span id = "L761" class = "LineNr" > 761 < / span > < span class = "Comment" > // strip stuff in parens from the name< / span >
< span id = "L762" class = "LineNr" > 762 < / span > < span class = "Normal" > const< / span > string& s = get< span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '010vm.cc.html#L357' > Name_f3< / a > < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > .< / span > data< span class = "Delimiter" > );< / span >
< span id = "L763" class = "LineNr" > 763 < / span > < span class = "Identifier" > return< / span > < span class = "Constant" > " (" < / span > +s< span class = "Delimiter" > .< / span > substr< span class = "Delimiter" > (< / span > < span class = "Constant" > 0< / span > < span class = "Delimiter" > ,< / span > s< span class = "Delimiter" > .< / span > find< span class = "Delimiter" > (< / span > < span class = "Constant" > " (" < / span > < span class = "Delimiter" > ))< / span > +< span class = "Constant" > ')'< / span > < span class = "Delimiter" > ;< / span >
< span id = "L764" class = "LineNr" > 764 < / span > < span class = "Delimiter" > }< / span >
< span id = "L765" class = "LineNr" > 765 < / span >
< span id = "L766" class = "LineNr" > 766 < / span > string < a href = '033check_operands.cc.html#L766' > maybe_name_f3_0f< / a > < span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > word& op< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L767" class = "LineNr" > 767 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > !is_hex_byte< span class = "Delimiter" > (< / span > op< span class = "Delimiter" > ))< / span > < span class = "Identifier" > return< / span > < span class = "Constant" > " " < / span > < span class = "Delimiter" > ;< / span >
< span id = "L768" class = "LineNr" > 768 < / span > < span class = "Normal" > if< / span > < span class = "Delimiter" > (< / span > !contains_key< span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '010vm.cc.html#L358' > Name_f3_0f< / a > < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > .< / span > data< span class = "Delimiter" > ))< / span > < span class = "Identifier" > return< / span > < span class = "Constant" > " " < / span > < span class = "Delimiter" > ;< / span >
< span id = "L769" class = "LineNr" > 769 < / span > < span class = "Comment" > // strip stuff in parens from the name< / span >
< span id = "L770" class = "LineNr" > 770 < / span > < span class = "Normal" > const< / span > string& s = get< span class = "Delimiter" > (< / span > < span class = "SpecialChar" > < a href = '010vm.cc.html#L358' > Name_f3_0f< / a > < / span > < span class = "Delimiter" > ,< / span > op< span class = "Delimiter" > .< / span > data< span class = "Delimiter" > );< / span >
< span id = "L771" class = "LineNr" > 771 < / span > < span class = "Identifier" > return< / span > < span class = "Constant" > " (" < / span > +s< span class = "Delimiter" > .< / span > substr< span class = "Delimiter" > (< / span > < span class = "Constant" > 0< / span > < span class = "Delimiter" > ,< / span > s< span class = "Delimiter" > .< / span > find< span class = "Delimiter" > (< / span > < span class = "Constant" > " (" < / span > < span class = "Delimiter" > ))< / span > +< span class = "Constant" > ')'< / span > < span class = "Delimiter" > ;< / span >
< span id = "L772" class = "LineNr" > 772 < / span > < span class = "Delimiter" > }< / span >
< span id = "L773" class = "LineNr" > 773 < / span >
< span id = "L774" class = "LineNr" > 774 < / span > string < a href = '033check_operands.cc.html#L774' > tolower< / a > < span class = "Delimiter" > (< / span > < span class = "Normal" > const< / span > < span class = "Normal" > char< / span > * s< span class = "Delimiter" > )< / span > < span class = "Delimiter" > {< / span >
< span id = "L775" class = "LineNr" > 775 < / span > ostringstream out< span class = "Delimiter" > ;< / span >
< span id = "L776" class = "LineNr" > 776 < / span > < span class = "Normal" > for< / span > < span class = "Delimiter" > (< / span > < span class = "Comment" > /*< / span > < span class = "Comment" > nada< / span > < span class = "Comment" > */< / span > < span class = "Delimiter" > ;< / span > *s< span class = "Delimiter" > ;< / span > ++s< span class = "Delimiter" > )< / span >
< span id = "L777" class = "LineNr" > 777 < / span > out < < < span class = "Normal" > static_cast< / span > < < span class = "Normal" > char< / span > > < span class = "Delimiter" > (< / span > < a href = '033check_operands.cc.html#L774' > tolower< / a > < span class = "Delimiter" > (< / span > *s< span class = "Delimiter" > ));< / span >
< span id = "L778" class = "LineNr" > 778 < / span > < span class = "Identifier" > return< / span > out< span class = "Delimiter" > .< / span > str< span class = "Delimiter" > ();< / span >
< span id = "L779" class = "LineNr" > 779 < / span > < span class = "Delimiter" > }< / span >
< span id = "L780" class = "LineNr" > 780 < / span >
< span id = "L781" class = "LineNr" > 781 < / span > < span class = "PreProc" > #undef HAS< / span >
< span id = "L782" class = "LineNr" > 782 < / span > < span class = "PreProc" > #undef SET< / span >
< span id = "L783" class = "LineNr" > 783 < / span > < span class = "PreProc" > #undef CLEAR< / span >
< span id = "L784" class = "LineNr" > 784 < / span >
< span id = "L785" class = "LineNr" > 785 < / span > < span class = "Delimiter" > :(before " End Includes" )< / span >
< span id = "L786" class = "LineNr" > 786 < / span > < span class = "PreProc" > #include< / span > < span class = "Constant" > < cctype> < / span >
2018-08-14 04:25:22 +00:00
< / pre >
< / body >
< / html >
<!-- vim: set foldmethod=manual : -->