mirror of
				https://github.com/espressif/binutils-gdb.git
				synced 2025-10-26 12:05:00 +08:00 
			
		
		
		
	S12Z: Don't crash when disassembling invalid instructions.
Check for null before dereferencing an operand pointer. Normally this situation should never arise, but could happen if a "partial" instruction is encountered at the end of a file or section. opcodes/ * s12z-dis.c (print_insn_s12z): Do not dereference an operand if it is null.
This commit is contained in:
		| @ -1,6 +1,8 @@ | |||||||
| 2019-01-09  John Darrington <john@darrington.wattle.id.au> | 2019-01-09  John Darrington <john@darrington.wattle.id.au> | ||||||
|  |  | ||||||
|         * s12z-dis.c (opr_emit_disassembly): Do not omit an index if it is | 	* s12z-dis.c (print_insn_s12z):  Do not dereference an operand | ||||||
|  | 	if it is null. | ||||||
|  | 	-dis.c (opr_emit_disassembly): Do not omit an index if it is | ||||||
| 	zero. | 	zero. | ||||||
|  |  | ||||||
| 2019-01-09  Andrew Paprocki  <andrew@ishiboo.com> | 2019-01-09  Andrew Paprocki  <andrew@ishiboo.com> | ||||||
|  | |||||||
| @ -359,7 +359,7 @@ print_insn_s12z (bfd_vma memaddr, struct disassemble_info* info) | |||||||
|       bool suffix = false; |       bool suffix = false; | ||||||
|       for (o = 0; o < n_operands; ++o) |       for (o = 0; o < n_operands; ++o) | ||||||
| 	{ | 	{ | ||||||
| 	  if (operands[o]->osize != -1) | 	  if (operands[o] && operands[o]->osize != -1) | ||||||
| 	    { | 	    { | ||||||
| 	      if (!suffix) | 	      if (!suffix) | ||||||
| 		{ | 		{ | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	 John Darrington
					John Darrington