Alan Modra
715537181e
PowerPC instruction mask checks
...
The instruction mask bits should never overlap any of the operands,
nor should operand bits overlap, but some operands weren't checked.
This patch arranges to check the omitted operands, using a mask
returned by the operand->insert function. Some tweaking of various
insert functions is needed to support this: The error case must set
field bits.
Since I was looking at the insert functions, I tidied some dead code
and simplified some of the powerpc_operands entries.
gas/
* config/tc-ppc.c (insn_validate): Don't ignore mask in
PPC_OPSHIFT_INV case. Call the insert function to calculate
a mask.
opcodes/
* ppc-opc.c (insert_arx, insert_ary, insert_rx, insert_ry, insert_ls),
(insert_evuimm1_ex0, insert_evuimm2_ex0, insert_evuimm4_ex0),
(insert_evuimm8_ex0, insert_evuimm_lt8, insert_evuimm_lt16),
(insert_rD_rS_even, insert_off_lsp, insert_off_spe2, insert_Ddd):
Don't return zero on error, insert mask bits instead.
(insert_sd4h, extract_sd4h, insert_sd4w, extract_sd4w): Delete.
(insert_sh6, extract_sh6): Delete dead code.
(insert_sprbat, insert_sprg): Use unsigned comparisions.
(powerpc_operands <OIMM>): Set shift count rather than using
PPC_OPSHIFT_INV.
<SE_SDH, SE_SDW>: Likewise. Don't use insert/extract functions.
2018-11-06 21:17:28 +10:30
..
2018-08-01 10:32:56 +09:30
2018-10-09 15:39:35 +01:00
2018-10-03 18:51:58 +01:00
2018-05-15 17:17:36 +01:00
2018-10-09 15:39:35 +01:00
2018-10-09 15:39:35 +01:00
2018-05-15 17:17:36 +01:00
2018-05-15 17:17:36 +01:00
2018-10-09 15:39:35 +01:00
2018-10-16 18:50:42 +01:00
2018-10-09 15:39:35 +01:00
2018-10-09 15:39:35 +01:00
2018-09-21 10:27:49 -04:00
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-09-20 15:49:00 +01:00
2018-07-23 11:09:43 +02:00
2018-08-06 16:41:32 +03:00
2018-07-23 11:09:43 +02:00
2018-10-19 10:33:11 +01:00
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-11-06 21:17:28 +10:30
2015-08-12 04:45:07 -07:00
2015-08-12 04:45:07 -07:00
2014-01-08 05:32:12 -08:00
2015-01-02 00:53:45 +10:30
2016-01-01 22:59:17 +10:30
2017-01-02 13:55:05 +10:30
2018-01-03 17:49:42 +10:30
2016-12-28 22:12:11 +10:30
2018-09-21 10:27:49 -04:00
2018-09-21 10:27:49 -04:00
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-05-09 15:55:28 +09:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-02-26 10:51:12 +10:30
2018-01-03 17:49:56 +10:30
2018-07-30 12:24:14 +01:00
2018-09-21 10:27:49 -04:00
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-09-20 13:32:58 +01:00
2018-07-30 12:24:14 +01:00
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-05-09 15:55:28 +09:30
2018-11-06 11:45:49 +01:00
2018-11-06 11:45:11 +01:00
2018-10-10 08:41:52 +02:00
2018-08-11 14:37:32 -07:00
2018-01-03 17:49:56 +10:30
2018-10-10 08:41:52 +02:00
2018-11-06 11:43:55 +01:00
2018-08-06 08:34:36 +02:00
2018-11-06 11:43:55 +01:00
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2013-05-17 12:57:16 +00:00
2013-05-17 12:57:16 +00:00
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-09-21 10:27:49 -04:00
2018-09-21 10:27:49 -04:00
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-02-13 13:14:47 +00:00
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-02-20 20:51:36 +00:00
2018-08-29 20:55:25 +08:00
2018-01-03 17:49:56 +10:30
2018-08-29 20:32:30 +08:00
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-06-01 13:10:33 +09:30
2018-06-01 13:10:33 +09:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-09-20 13:32:58 +01:00
2018-09-20 13:32:58 +01:00
2018-09-20 13:32:58 +01:00
2018-01-03 17:49:56 +10:30
2018-06-26 12:56:23 +01:00
2018-09-23 12:31:23 -07:00
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-10-05 11:41:41 +09:00
2018-10-05 11:41:42 +09:00
2018-10-05 11:41:42 +09:00
2018-10-05 11:41:41 +09:00
2018-10-05 11:41:41 +09:00
2018-10-05 11:41:42 +09:00
2018-10-05 11:41:42 +09:00
2018-10-05 11:41:42 +09:00
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-08-21 16:05:36 +09:30
2018-11-06 21:17:28 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-08-30 13:23:12 -07:00
2018-10-02 08:26:32 -07:00
2018-06-01 13:10:33 +09:30
2018-06-01 13:10:33 +09:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-10-22 20:53:15 +02:00
2018-07-02 23:57:21 +01:00
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-10-23 18:13:01 +02:00
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-04-16 15:29:39 +09:30
2018-08-20 09:54:20 +09:30
2018-03-03 11:34:26 +10:30
2018-08-29 20:52:28 +02:00
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-06-01 13:10:33 +09:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-02-13 12:56:29 +00:00
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-03-03 11:34:26 +10:30
2018-03-03 11:34:26 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-06-06 21:30:36 +09:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30
2018-01-03 17:49:56 +10:30