]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blame - sim/bfin/ChangeLog
daily update
[thirdparty/binutils-gdb.git] / sim / bfin / ChangeLog
CommitLineData
48a93897
MF
12013-06-23 Mike Frysinger <vapier@gentoo.org>
2
3 * bfin-sim.c (decode_dsp32alu_0): Add note about broken handling of
4 SEARCH with parallel insns.
5
03dccef1
MF
62013-06-23 Mike Frysinger <vapier@gentoo.org>
7
8 * bfin-sim.c (decode_dsp32shift_0): Make sure HLs is 0 after last
9 insn that uses it.
10 (decode_dsp32shiftimm_0): Likewise.
11 Require HLs be less than 2 for accumulator shift insns.
12
f7f8a049
MF
132013-06-18 Mike Frysinger <vapier@gentoo.org>
14
15 * bfin-sim.c (decode_dsp32alu_0): Check more opcode fields before
16 decoding various insns.
17
7935c6b0
MF
182013-06-17 Mike Frysinger <vapier@gentoo.org>
19
20 * TODO: Add more notes.
21
b241c890
MF
222013-06-09 Mike Frysinger <vapier@gentoo.org>
23
24 * Makefile.in ($(srcdir)/linux-fixed-code.h): Add
25 @MAINTAINER_MODE_TRUE@ as the first item in the dependency list.
26
31e6ad7d
MF
272013-06-03 Mike Frysinger <vapier@gentoo.org>
28
29 * aclocal.m4, configure: Regenerate.
30
d3685d60
TT
312013-05-10 Freddie Chopin <freddie_chopin@op.pl>
32
33 * configure: Rebuild.
34
1517bd27
MF
352013-03-26 Mike Frysinger <vapier@gentoo.org>
36
37 * aclocal.m4, configure: Regenerate.
38
256139f5
JS
392013-03-23 Joel Sherrill <joel.sherrill@oarcorp.com>
40
41 * configure.ac: Use $SIM_DV_SOCKSER_O.
42 * configure: Regenerated.
43
048a61aa
JB
442012-12-20 Joel Brobecker <brobecker@adacore.com>
45
46 * aclocal.m4: Revert the previous change changing
47 the license from GPL v2 or later to GPL v3 or later
48 (this file was generated).
49
d2cec111
JB
502012-12-20 Joel Brobecker <brobecker@adacore.com>
51
52 * linux-fixed-code.s: Revert the previous change changing
53 the license from GPL v2 or later to GPL v3 or later.
54
040a4d10
MF
552012-07-31 Mike Frysinger <vapier@gentoo.org>
56
57 * machs.c (bf54x_roms): Pass 0x1000 to alias field of BFROM, and
58 0x10000 to the alias field of BFROMA.
59 (bf561_roms): Pass 0x1000 to alias field of BFROM.
60 (bf59x_roms): Pass 0x10000 to alias field of BFROMA.
61
b5539f23
MF
622012-07-31 Mike Frysinger <vapier@gentoo.org>
63
64 * machs.c (bfin_reg_fetch): Change return 0 to return -1, and
65 return -1 to return 4.
66 (bfin_reg_store): Likewise.
67
5f3ef9d0
JB
682012-06-15 Joel Brobecker <brobecker@adacore.com>
69
70 * config.in, configure: Regenerate.
71
050396e5
MF
722012-04-09 Mike Frysinger <vapier@gentoo.org>
73
74 * configure.ac (SIM_AC_OPTION_HARDWARE): Add bfin_pint.
75 * configure: Regenerate.
76 * dv-bfin_pint.c, dv-bfin_pint.h: New device model.
77 * machs.c (bf542_dev): Add PINT register blocks.
78 (bf544_dev, bf547_dev): Likewise.
79 (PINT_PIQS): Define.
80 (bf54x_port): Add pint/gpio routing.
81 * machs.h (BFIN_MMR_PINT_SIZE): Define.
82
07c5891d
MF
832012-04-09 Mike Frysinger <vapier@gentoo.org>
84
85 * configure.ac (SIM_AC_OPTION_HARDWARE): Add bfin_gpio2.
86 * configure: Regenerate.
87 * dv-bfin_gpio2.c, dv-bfin_gpio2.h: New device model.
88 * machs.c (bf54x_mem): Delete GPIO mem stub.
89 (bf542_dev): Add GPIO register blocks.
90 (bf544_dev, bf547_dev): Likewise.
91 * machs.h (BFIN_MMR_GPIO2_SIZE): Define.
92
c0c46382
MF
932012-04-09 Robin Getz <robin.getz@analog.com>
94
95 * bfin-sim.c (decode_dsp32shift_0): Extract the sign for ASHIFT
96 and LSHIFT, and set ASTAT based on the before/after values.
97 Rename "val" to "acc" to be consistent with other code branches.
98
ef0b041e
MF
992012-04-09 Robin Getz <robin.getz@analog.com>
100
101 * bfin-sim.c (sgn_extend): New helper.
102 (decode_dsp32shiftimm_0): Call lshift when newimmag is more
103 than 16, otherwise call ashiftrt. Set ASTAT fields as needed.
104 For accumulator shifts, call new sgn_extend helper.
105
ab04c000
MF
1062012-04-08 Mike Frysinger <vapier@gentoo.org>
107
108 * bfin-sim.c (illegal_instruction_or_combination): New helper.
109 (decode_ProgCtrl_0): Call illegal_instruction_or_combination instead
110 of illegal_instruction.
111 (decode_PushPopReg_0, decode_CCflag_0, decode_CC2dreg_0,
112 decode_LDSTpmod_0, decode_dagMODim_0, decode_dagMODik_0,
113 decode_dspLDST_0, decode_LDST_0, _interp_insn_bfin): Likewise.
114 (decode_PushPopMultiple_0): Call illegal_instruction_combination when
115 PARALLEL_GROUP is not BFIN_PARALLEL_NONE.
116 (decode_CCflag_0, decode_REGMV_0, decode_ALU2op_0, decode_PTR2op_0,
117 decode_COMPI2opD_0, decode_COMPI2opP_0): Likewise.
118 (decode_CC2stat_0): Check PARALLEL_GROUP before cbit.
119 (decode_LDSTpmod_0): Call illegal_instruction_combination when
120 PARALLEL_GROUP is BFIN_PARALLEL_GROUP2.
121 (decode_dagMODim_0, decode_dagMODik_0, decode_LDST_0,
122 decode_LDSTiiFP_0, decode_LDSTii_0): Likewise.
123
99265d6b
MF
1242012-04-08 Mike Frysinger <vapier@gentoo.org>
125
126 * bfin-sim.h (bfin_parallel_group): New enum.
127 (bfin_cpu_state): Add new "group" member.
128 (PARALLEL_GROUP): Define.
129 * bfin-sim.c (decode_ProgCtrl_0): Change INSN_LEN check to
130 PARALLEL_GROUP.
131 (decode_CaCTRL_0, decode_PushPopReg_0, decode_ccMV_0, decode_CCflag_0,
132 decode_CC2dreg_0, decode_CC2stat_0, decode_BRCC_0, decode_UJUMP_0,
133 decode_LOGI2op_0, decode_LoopSetup_0, decode_LDIMMhalf_0,
134 decode_CALLa_0, decode_linkage_0): Likewise.
135 (_interp_insn_bfin): Set PARALLEL_GROUP.
136 (interp_insn_bfin): Likewise.
137
a8a0e37c
MF
1382012-04-08 Mike Frysinger <vapier@gentoo.org>
139
140 * bfin-sim.c (decode_dsp32alu_0): Delete extra space in TRACE_INSN.
141
1d18e989
MF
1422012-04-01 Mike Frysinger <vapier@gentoo.org>
143
144 * bfin-sim.c (_interp_insn_bfin): Call illegal_instruction_combination
145 when INSN_LEN is non-zero before 32bit decode.
146
2fa7a057
MF
1472012-04-01 Mike Frysinger <vapier@gentoo.org>
148
149 * bfin-dis.c (fmtconst): Replace decimal handling with a single
150 sprintf call and the '*' field width.
151
02bb38cc
MF
1522012-04-01 Mike Frysinger <vapier@gentoo.org>
153
154 * machs.c (bfin_model_map_bfrom): Return when mnum is 535.
155
e4967d72
MF
1562012-04-01 Mike Frysinger <vapier@gentoo.org>
157
158 * interp.c (bfin_user_init): Move auxvt_size decl from top to
159 inside of auxvt check.
160
8d72c970
MF
1612012-03-31 Mike Frysinger <vapier@gentoo.org>
162
163 * dv-bfin_sic.c (bfin_sic_finish): Change iwr1 to iwr2.
164
a4a66f71
MF
1652012-03-31 Mike Frysinger <vapier@gentoo.org>
166
167 * devices.c: Include devices.h.
168
2232061b
MF
1692012-03-24 Mike Frysinger <vapier@gentoo.org>
170
171 * aclocal.m4, config.in, configure: Regenerate.
172
e62bb22a
MF
1732012-03-19 Robin Getz <robin.getz@analog.com>
174 Mike Frysinger <vapier@gentoo.org>
175
176 * bfin-sim.c (lshift): Add an overflow flag. Delete now unused
177 i, j, and tmp vars. Add a new v_i var. Split the overflow logic
178 out from the saturate logic. Do not set V ASTAT bits when working
179 with accumulators.
180 (decode_ALU2op_0): Add new argument to lshift call.
181 (decode_LOGI2op_0, decode_dsp32shift_0, decode_dsp32shiftimm_0):
182 Likewise.
183
8dbfaed8
MF
1842012-03-18 Mike Frysinger <vapier@gentoo.org>
185
186 * dv-bfin_ebiu_amc.c (struct bfin_ebiu_amc): Add bank_base.
187 (bfin_ebiu_amc_write_amgctl): Replace BFIN_EBIU_AMC_BASE with
188 amc->bank_base.
189 (bfin_ebiu_amc_finish): Assign BFIN_EBIU_AMC_BASE to amc->bank_base.
190
410bbc94
MF
1912012-03-18 Mike Frysinger <vapier@gentoo.org>
192
193 * dv-bfin_ebiu_amc.c (bfin_ebiu_amc_attach_address_callback): Use
194 ARRAY_SIZE rather than hardcoded constant.
195
84de2f06
MF
1962012-02-04 Mike Frysinger <vapier@gentoo.org>
197
198 * config.in: Regenerate.
199 * configure: Likewise.
200 * configure.ac: Add linux/types.h to AC_CHECK_HEADERS.
201 * dv-eth_phy.c: Check for HAVE_LINUX_TYPES_H, and delete __u16 and
202 _LINUX_TYPES_H defines.
203
cc5add8c
MF
2042011-12-03 Mike Frysinger <vapier@gentoo.org>
205
206 * interp.c (bfin_syscall): Increase _tbuf storage. Declare new local
207 tstr buffer. Call cb_get_string on tstr when handling CB_SYS_stat64,
208 CB_SYS_lstat64, CB_SYS_open, CB_SYS_write, CB_SYS_unlink,
209 CB_SYS_truncate, CB_SYS_rename, CB_SYS_stat, CB_SYS_lstat. Include
210 tstr in the tbuf output.
211
db2e4d67
MF
2122011-12-03 Mike Frysinger <vapier@gentoo.org>
213
214 * Makefile.in: Delete all dependency rules.
215 * aclocal.m4, configure: Regenerate.
216
4399a56b
MF
2172011-10-19 Mike Frysinger <vapier@gentoo.org>
218
219 * configure: Regenerate after common/acinclude.m4 update.
220
9c082ca8
MF
2212011-10-17 Mike Frysinger <vapier@gentoo.org>
222
223 * configure.ac: Change include to common/acinclude.m4.
224 * aclocal.m4, configure: Regenerate.
225
6ffe910a
MF
2262011-10-17 Mike Frysinger <vapier@gentoo.org>
227
228 * configure.ac: Change AC_PREREQ to 2.64. Delete AC_CONFIG_HEADER
229 call. Replace common.m4 include with SIM_AC_COMMON.
230 * configure: Regenerate.
231
39c1f96a
MF
2322011-09-28 Mike Frysinger <vapier@gentoo.org>
233
234 * bfin-sim.c (decode_dsp32shift_0): Use STORE() for VIT_MAX insns.
235
2419798b
MF
2362011-07-05 Mike Frysinger <vapier@gentoo.org>
237
238 * interp.c (sim_do_command): Delete.
239
a931db6a
MF
2402011-07-01 Mike Frysinger <vapier@gentoo.org>
241
242 * interp.c (cb_linux_stat_map_32, cb_linux_stat_map_64): Rename from
243 stat_map_32 and stat_map_64.
244 (cb_libgloss_stat_map_32): New stat map.
245 (stat_map_32, stat_map_64): New stat map pointers.
246 (bfin_user_init): Assign stat_map_32 to cb_linux_stat_map_32 and
247 stat_map_64 to cb_linux_stat_map_64.
248 (bfin_virtual_init): New function.
249 (sim_create_inferior): Call bfin_virtual_init for all other envs.
250
ce2486ab
MF
2512011-06-22 Mike Frysinger <vapier@gentoo.org>
252
253 * interp.c (bfin_syscall): Delete old comment. Set dreg 1 to
254 sc.result2 and dreg 2 to sc.errcode.
255
1f20b145
MF
2562011-06-18 Robin Getz <robin.getz@analog.com>
257
258 * bfin-sim.c (decode_dsp32shift_0): Clear ASTAT[AV] if val is 0,
259 else set it. Set ASTAT[AVS] if val is 0. Do this for LSHIFT and
260 ASHIFT accumulator insns.
261
b4876e04
MF
2622011-06-18 Robin Getz <robin.getz@analog.com>
263
264 * bfin-sim.c (ashiftrt): If size is 40, do not call SET_ASTATREG.
265 (lshiftrt): Likewise.
266
d5fcd950
MF
2672011-06-18 Robin Getz <robin.getz@analog.com>
268
269 * bfin-sim.c (decode_dsp32shift_0): Use get_unextended_acc
270 rather than get_extended_acc in LSHIFT insns.
271
a56a1954
MF
2722011-06-18 Robin Getz <robin.getz@analog.com>
273
274 * bfin-sim.c (decode_macfunc): Handle MM when mmod is M_TFU.
275 Check MM once when mmod is M_FU to match M_TFU better.
276
90e13d65
MF
2772011-06-18 Robin Getz <robin.getz@analog.com>
278
279 * bfin-sim.c (decode_dsp32shiftimm_0): When shift is greater than
280 32, perform a left shift. Update the corresponding AV bit. Set
281 AZ when the low 32bits are also zero.
282
99dcc4dc
MF
2832011-06-18 Robin Getz <robin.getz@analog.com>
284
285 * bfin-sim.c (decode_dsp32shiftimm_0): With left shift vector insns,
286 call lshift only when count is positive. Otherwise, call ashiftrt.
287 With arithmetic right shift insns, call ashiftrt when the value is
288 small enough, otherwise call lshift.
289
a0a71a7f
MF
2902011-06-18 Robin Getz <robin.getz@analog.com>
291
292 * bfin-sim.c (extract_mult): Call saturate_s16 directly when
293 mmod is M_IH rather than computing the result by hand.
294
388aa9fe
MF
2952011-06-18 Robin Getz <robin.getz@analog.com>
296
297 * bfin-sim.c (decode_macfunc): Add nosat_acc to track acc value
298 before saturation, set sat when more cases saturate, and set the
299 overflow bit based on these results. For M_TFU, M_IU, M_FU, and
300 M_W32, change the max values compared against.
301 (decode_dsp32mac_0): Delete v_i and add v_0 and v_1. Pass v_1
302 when processing MAC1 and pass v_0 when processing MAC0. Combine
303 the results into the V/VS ASTAT bits.
304
f2a56d0a
MF
3052011-06-18 Robin Getz <robin.getz@analog.com>
306
307 * bfin-sim.c (extract_mult): Call saturate_s32 when MM is set
308 and mmod is M_IU. Call saturate_s16 when MM is set and mmod
309 is M_TFU.
310
ef26d60e
MF
3112011-06-18 Robin Getz <robin.getz@analog.com>
312
313 * bfin-sim.c (decode_multfunc): Call new is_macmod_signed, and
314 allow MM to sign extend all the time.
315 (decode_macfunc): Likewise. Drop sign extension of unsigned
316 values.
317
73aae8ef
MF
3182011-06-18 Robin Getz <robin.getz@analog.com>
319
b02cc5b9 320 * bfin-sim.c (saturate_s40_astat): Change ">=" to ">".
73aae8ef
MF
321 (decode_macfunc): Likewise when mmod is M_IH.
322
886ea33b
MF
3232011-06-18 Mike Frysinger <vapier@gentoo.org>
324
325 * interp.c (sim_create_inferior): Change free to freeargv.
326
eb324344
MF
3272011-06-04 Mike Frysinger <vapier@gentoo.org>
328
329 * machs.c (bf534_dev, bf537_dev): Add glue-or devices.
330 (bf537_port): Define applicable devices with PORT to the glue-or
331 devices instead of SIC.
332 (bfin_model_hw_tree_init): Drop old sim_hw_parse call for bfin_sic.
333 Only parse reg/type when the device has an address. Move the call
334 to dv_bfin_hw_port_parse up before slash check.
335
082e1c4a
MF
3362011-06-04 Mike Frysinger <vapier@gentoo.org>
337
338 * dv-bfin_sic.c (ENC, DEC_PIN, DEC_SIC): Move above the
339 BFIN_SIC_TO_CEC_PORTS definition.
340 (SIC_PORTS): New define.
341 (bfin_sic_50x_ports, bfin_sic_51x_ports, bfin_sic_52x_ports,
342 bfin_sic_533_ports, bfin_sic_537_ports, bfin_sic_538_ports,
343 bfin_sic_54x_ports, bfin_sic_561_ports, bfin_sic_59x_ports):
344 Delete old layouts.
345 (bfin_sic1_ports, bfin_sic2_ports, bfin_sic3_ports,
346 bfin_sic_561_ports): Define new layouts with SIC_PORTS().
347 (bfin_sic_finish): Change reference to bfin_sic_50x_ports,
348 bfin_sic_51x_ports, bfin_sic_52x_ports, and bfin_sic_538_ports
349 to bfin_sic2_ports. Change reference to bfin_sic_533_ports,
350 bfin_sic_537_ports, and bfin_sic_59x_ports to bfin_sic1_ports.
351 Change reference to bfin_sic_54x_ports to bfin_sic3_ports.
352 * machs.c (bfin_port_layout): New structure.
353 (bfin_model_data): Add new "port" and "port_count" members.
354 (PORT, SIC): New defines.
355 (bf000_port, bf50x_port, bf51x_port, bf52x_port, bf533_port,
356 bf537_port, bf538_port, bf54x_port, bf561_port, bf592_port):
357 Move and redefine port layout from dv-bfin_sic.c to here.
358 (bf504_port, bf506_port, bf512_port, bf514_port, bf516_port,
359 bf518_port, bf522_port, bf523_port, bf524_port, bf525_port,
360 bf526_port, bf527_port, bf531_port, bf532_port, bf534_port,
361 bf536_port, bf539_port, bf542_port, bf544_port, bf547_port,
362 bf548_port, bf549_port): New defines.
363 (bfin_model_data): Link in new bfin_port_layout.port member.
364 (dv_bfin_hw_port_parse): New function.
365 (dv_bfin_hw_parse): Call new dv_bfin_hw_port_parse function.
366 (bfin_model_hw_tree_init): Replace calls to sim_hw_parse for
367 bfin_sic links with new dv_bfin_hw_port_parse function.
368
36f3e981
MF
3692011-06-03 Mike Frysinger <vapier@gentoo.org>
370
371 * dv-bfin_dma.c (bfin_dma_io_write_buffer): Fix indentation.
372
ea1f7d4c
MF
3732011-05-25 Mike Frysinger <vapier@gentoo.org>
374
375 * sim-main.h (TRACE_SYSCALL): Change EVENTS to SYSCALL.
376
f2db709f
MF
3772011-05-25 Mike Frysinger <vapier@gentoo.org>
378
379 * dv-bfin_cec.h (BFIN_COREMMR_CEC_{BASE,SIZE}): Move to ...
380 * dv-bfin_ctimer.h (BFIN_COREMMR_CTIMER_{BASE,SIZE}): Move to ...
381 * dv-bfin_dma.h (BFIN_MMR_DMA_SIZE): Move to ...
382 * dv-bfin_dmac.h (BFIN_MMR_DMAC{0,1}_BASE): Move to ...
383 * dv-bfin_ebiu_amc.h (BF{IN,50X,54X}_MMR_EBIU_AMC_SIZE): Move to ...
384 * dv-bfin_ebiu_ddrc.h (BFIN_MMR_EBIU_DDRC_SIZE): Move to ...
385 * dv-bfin_ebiu_sdc.h (BFIN_MMR_EBIU_SDC_SIZE): Move to ...
386 * dv-bfin_emac.h (BFIN_MMR_EMAC_{BASE,SIZE}): Move to ...
387 * dv-bfin_eppi.h (BFIN_MMR_EPPI_SIZE): Move to ...
388 * dv-bfin_evt.h (BFIN_COREMMR_EVT_{BASE,SIZE}): Move to ...
389 * dv-bfin_gpio.h (BFIN_MMR_GPIO_SIZE): Move to ...
390 * dv-bfin_gptimer.h (BFIN_MMR_GPTIMER_SIZE): Move to ...
391 * dv-bfin_jtag.h (BFIN_COREMMR_JTAG_{BASE,SIZE}): Move to ...
392 * dv-bfin_mmu.h (BFIN_COREMMR_MMU_{BASE,SIZE}): Move to ...
393 * dv-bfin_nfc.h (BFIN_MMR_NFC_SIZE): Move to ...
394 * dv-bfin_otp.h (BFIN_MMR_OTP_SIZE): Move to ...
395 * dv-bfin_pfmon.h (BFIN_COREMMR_PFMON_{BASE,SIZE}): Move to ...
396 * dv-bfin_pll.h (BFIN_MMR_PLL_{BASE,SIZE}): Move to ...
397 * dv-bfin_ppi.h (BFIN_MMR_PPI_SIZE): Move to ...
398 * dv-bfin_rtc.h (BFIN_MMR_RTC_SIZE): Move to ...
399 * dv-bfin_sic.h (BFIN_MMR_SIC_{BASE,SIZE}): Move to ...
400 * dv-bfin_spi.h (BFIN_MMR_SPI_SIZE): Move to ...
401 * dv-bfin_trace.h (BFIN_COREMMR_TRACE_{BASE,SIZE}): Move to ...
402 * dv-bfin_twi.h (BFIN_MMR_TWI_SIZE): Move to ...
403 * dv-bfin_uart.h (BFIN_MMR_UART_SIZE): Move to ...
404 * dv-bfin_uart2.h (BFIN_MMR_UART2_SIZE): Move to ...
405 * dv-bfin_wdog.h (BFIN_MMR_WDOG_SIZE): Move to ...
406 * dv-bfin_wp.h (BFIN_COREMMR_WP_{BASE,SIZE}): Move to ...
407 * machs.h: ... here.
408 * machs.c: Delete all dv-bfin_*.h includes except for cec/dmac.
409
c43aadca
MF
4102011-05-25 Mike Frysinger <vapier@gentoo.org>
411
412 * Makefile.in (dv-bfin_pfmon.o): New target.
413 * configure.ac (SIM_AC_OPTION_HARDWARE): Add bfin_pfmon.
414 * configure: Regenerated.
415 * dv-bfin_pfmon.c, dv-bfin_pfmon.h: New files.
416 * machs.c: Add include new bfin_pfmon.h.
417 (bfin_core_dev): Add pfmon.
418
dfb61fb6
MF
4192011-05-25 Mike Frysinger <vapier@gentoo.org>
420
421 * machs.c (bf526_roms): Add a region with rev of 2.
422 (bf54x_roms): Add regions with rev of 4.
423 * bfroms/all.h: Include new bf526-0.2.h, bf54x-0.4.h, and
424 bf54x_l1-0.4.h headers.
425 * bfroms/bf526-0.2.h, bfroms/bf54x-0.4.h, bfroms/bf54x_l1-0.4.h:
426 New header files.
427
efac2223
MF
4282011-05-14 Mike Frysinger <vapier@gentoo.org>
429
430 * bfin-sim.c (decode_PushPopReg_0): Delete (grp == 1 && reg == 6)
431 check for SP reg.
432
28fe96b7
MF
4332011-05-14 Mike Frysinger <vapier@gentoo.org>
434
435 * dv-bfin_uart.c (bfin_uart_write_byte): Add a mcr arg. Declare a
436 local uart. When LOOP_ENA is set in mcr, write to the saved byte
437 and count fields of the uart.
438 (bfin_uart_io_write_buffer): Pass uart->mcr to bfin_uart_write_byte
439 and bfin_uart_get_next_byte.
440 (bfin_uart_get_next_byte): Add a mcr arg. Move uart->saved_count
441 check first, and skip the remaining code when LOOP_ENA is set in mcr.
442 * dv-bfin_uart.h (bfin_uart_write_byte): Add an mcr argument.
443 (bfin_uart_get_next_byte): Likewise.
444 (XOFF, MRTS, RFIT, RFRT, LOOP_ENA, FCPOL, ARTS, ACTS): Define.
445 * dv-bfin_uart2.c (bfin_uart_io_write_buffer): Padd uart->mcr when
446 calling bfin_uart_write_byte and bfin_uart_get_next_byte.
447
b44f3f63
MF
4482011-05-09 Mike Frysinger <vapier@gentoo.org>
449
450 * dv-bfin_uart2.c (bfin_uart_io_read_buffer): Clear DR/THRE/TEMT bits
451 from uart->lsr before setting them.
452
2613074f
MF
4532011-04-27 Mike Frysinger <vapier@gentoo.org>
454
455 * dv-bfin_dmac.c (bfin_dmac): Constify pmap array.
456 (bfin_dmac_50x_pmap, bfin_dmac_51x_pmap, bfin_dmac_52x_pmap,
457 bfin_dmac_533_pmap, bfin_dmac_537_pmap, bfin_dmac0_538_pmap,
458 bfin_dmac1_538_pmap, bfin_dmac0_54x_pmap, bfin_dmac1_54x_pmap,
459 bfin_dmac0_561_pmap, bfin_dmac1_561_pmap, bfin_dmac_59x_pmap):
460 Likewise.
461
054c055b
MF
4622011-04-26 Mike Frysinger <vapier@gentoo.org>
463
464 * dv-bfin_gpio.c (bfin_gpio_forward_ouput): New function.
465 (bfin_gpio_io_write_buffer): Store the current port state into
466 "data", and call bfin_gpio_forward_ouput when the data or dir
467 MMRs are updated.
468 (bfin_gpio_ports): Change p0..p15 to bidirect_port.
469
5e0ba1a3
MF
4702011-04-26 Mike Frysinger <vapier@gentoo.org>
471
472 * dv-bfin_gpio.c (bfin_gpio): Add "int_state" member.
473 (bfin_gpio_forward_int, bfin_gpio_forward_ints): New functions.
474 (bfin_gpio_io_write_buffer): Call bfin_gpio_forward_int when the
475 mask a or mask b MMRs are written.
476 (bfin_gpio_port_event): When handling edge gpios, set the bit in
477 int_state, call bfin_gpio_forward_ints, and then clear the bit.
478 When handling level gpios, clear/set the bit in int_state rather
479 than returning immediately. Call bfin_gpio_forward_ints instead
480 of checking mask[ab] and calling HW_TRACE/hw_port_event directly.
481
0427acfb
MF
4822011-04-16 Mike Frysinger <vapier@gentoo.org>
483
484 * bfin-sim.c (decode_dsp32alu_0): Call STORE instead of SET_DREG for
485 BYTEOP2P, BYTEOP3P, BYTEOP1P, BYTEOP16P, BYTEOP16M, BYTEPACK, and
486 BYTEUNPACK.
487 (decode_dsp32shift_0): Call STORE instead of SET_DREG for PACK,
488 BITMUX, EXTRACT, DEPOSIT, ALIGN8, ALIGN16, and ALIGN24.
489
d2cfa400
MF
4902011-04-14 Mike Frysinger <vapier@gentoo.org>
491
492 * bfin-sim.c (decode_dsp32alu_0): Set DIS_ALGN_EXPT when handling
493 BYTEOP2P, BYTEOP3P, SAA, BYTEOP1P, BYTEOP16P, BYTEOP16M, BYTEPACK,
494 and BYTEUNPACK insns.
495
e10d6db3
MF
4962011-04-11 Mike Frysinger <vapier@gentoo.org>
497
498 * dv-bfin_sic.c (bfin_sic_port_event): New helper function.
499 (bfin_sic_52x_port_event, bfin_sic_537_port_event,
500 bfin_sic_54x_port_event, bfin_sic_561_port_event): Include level
501 in the trace output, and call the new bfin_sic_port_event func.
502
8aacdaf4
MF
5032011-04-11 Mike Frysinger <vapier@gentoo.org>
504
505 * dv-bfin_gpio.c (bfin_gpio_ports): Add p15.
506
2b12772f
MF
5072011-04-01 Mike Frysinger <vapier@gentoo.org>
508
509 * dv-bfin_otp.c (bfin_otp_ports): Declare.
510 (bfin_otp_finish): Call set_hw_ports with bfin_otp_ports.
511
6294f8ea
MF
5122011-03-29 Mike Frysinger <vapier@gentoo.org>
513
514 * configure: Regenerate after common/aclocal.m4 changes.
515
1a3af0bf
MF
5162011-03-28 Robin Getz <robin.getz@analog.com>
517
518 * bfin-sim.c (decode_dsp32alu_0): Cast high 16bits of A0.W to bs16
519 and add to casted low 16bits of A0.L and store in val0. Cast high
520 16bits of A1.W to bs16 and add to casted low 16bits of A1.L and
521 store in val1. Delete bit checks of val0 and val1.
522
36aef942
MF
5232011-03-26 Robin Getz <robin.getz@analog.com>
524
525 * bfin-sim.c (decode_dsp32alu_0): Set result to 0x7FFFFFFF when
526 the result was 0x80000000 for RND12 subtraction.
527
fcd1ee07
MF
5282011-03-26 Robin Getz <robin.getz@analog.com>
529
530 * bfin-sim.c (decode_dsp32alu_0): Set VS when V is set.
531
a31d4fd9
MF
5322011-03-24 Mike Frysinger <vapier@gentoo.org>
533
534 * dv-bfin_gpio.c (bfin_gpio_port_event): Call HW_TRACE at every
535 major code flow point.
536 * dv-bfin_sic.c (bfin_sic_forward_interrupts): Call HW_TRACE just
537 before calling hw_port_event on ourselves.
538 (bfin_sic_52x_port_event, bfin_sic_537_port_event,
539 bfin_sic_54x_port_event, bfin_sic_561_port_event): Call HW_TRACE
540 at the start of the function.
541
b72cc8e1
MF
5422011-03-24 Mike Frysinger <vapier@gentoo.org>
543
544 * dv-bfin_gpio.c (bfin_gpio_port_event): Split dir/inen bit checking.
545 Normalize "level" to 0/1 values. Shift "level" over by "my_port".
546 Invert port->both bit check.
547
eaf863cd
MF
5482011-03-24 Mike Frysinger <vapier@gentoo.org>
549
550 * dv-bfin_gpio.c (bfin_gpio_io_write_buffer): Subtract 2 from the
551 valuep pointer for clear MMRs, 4 for set MMRs, and 6 for toggle MMRs.
552
b16a1f4c
MF
5532011-03-23 Mike Frysinger <vapier@gentoo.org>
554
555 * TODO: Document some known SIC issues.
556
9922f803
MF
5572011-03-23 Mike Frysinger <vapier@gentoo.org>
558
559 * devices.h (dv_w1c): Fix typos in documentation of "bits" arg.
560 * dv-bfin_cec.c (bfin_cec_io_write_buffer): Pass 0xffee to dv_w1c_4.
561 * dv-bfin_emac.c (bfin_emac_io_write_buffer): Pass 0xe1 to dv_w1c_4
562 for systat MMR and -1 to dv_w1c_4 for [rt]x_stky/mmc_[rt]irqs MMRs.
563 * dv-bfin_eppi.c (bfin_eppi_io_write_buffer): Pass 0x1ff to dv_w1c_2.
564 * dv-bfin_gpio.c (bfin_gpio_io_write_buffer): Invert bits to dv_w1c_2.
565 * dv-bfin_jtag.c (bfin_jtag_io_write_buffer): Invert bits to dv_w1c_4.
566 * dv-bfin_nfc.c (bfin_nfc_io_write_buffer): Invert bits to dv_w1c_2.
567 * dv-bfin_otp.c (bfin_otp_io_write_buffer): Invert bits to dv_w1c_2.
568 * dv-bfin_ppi.c (bfin_ppi_io_write_buffer): Invert bits to dv_w1c_2.
569 * dv-bfin_rtc.c (bfin_rtc_io_write_buffer): Invert bits to dv_w1c_2.
570 * dv-bfin_spi.c (bfin_spi_io_write_buffer): Invert bits to dv_w1c_2.
571 * dv-bfin_twi.c (bfin_twi_io_write_buffer): Invert bits to dv_w1c_2.
572 * dv-bfin_uart2.c (bfin_uart_io_write_buffer): Invert bits to dv_w1c_2.
573
2d2bab5b
MF
5742011-03-23 Mike Frysinger <vapier@gentoo.org>
575
576 * dv-bfin_uart.h (TFI, BI, FE, PE, OE): Define.
577
972dbc8a
MF
5782011-03-23 Mike Frysinger <vapier@gentoo.org>
579
580 * dv-bfin_twi.h (LOSTARB): Rename from LOSTARG.
581
8e670c0a
MF
5822011-03-23 Robin Getz <robin.getz@analog.com>
583
584 * bfin-sim.c (decode_dsp32shift_0): Set acc0 to the unextended
585 value for the VIT_MAX insn, and mask off the result when done.
586
de0addfb
MF
5872011-03-23 Robin Getz <robin.getz@analog.com>
588
589 * bfin-sim.c (decode_dsp32alu_0): Set A1 to a1_lo when up_hi is false,
590 and set A0 to a0_lo when up_lo is false.
591
beb378a5
MF
5922011-03-23 Robin Getz <robin.getz@analog.com>
593
594 * bfin-sim.c (decode_dsp32alu_0): Call saturate_s40_astat instead of
595 saturate_s40, and use the v parameter to update the AV bit. Set the
596 AC bit only when the final result is 0.
597
e4a861d1
MF
5982011-03-23 Mike Frysinger <vapier@gentoo.org>
599
600 * dv-bfin_sic.c (ENC, DEC_PIN, DEC_SIC): Define.
601 (bfin_sic_50x_ports, bfin_sic_51x_ports, bfin_sic_52x_ports,
602 bfin_sic_533_ports, bfin_sic_537_ports, bfin_sic_538_ports,
603 bfin_sic_54x_ports, bfin_sic_561_ports, bfin_sic_59x_ports):
604 Encode ids with the ENC macro.
605 (bfin_sic_52x_port_event, bfin_sic_537_port_event,
606 bfin_sic_54x_port_event, bfin_sic_561_port_event): Set idx
607 from my_port with DEC_SIC, and set bit from my_port with DEC_PIN.
608 (bfin_sic_533_port_event): Delete.
609 (bfin_sic_finish): Call set_hw_port_event with
610 bfin_sic_537_port_event for BF533 and BF59x targets.
611
8d8a9746
MF
6122011-03-23 Robin Getz <robin.getz@analog.com>
613
614 * bfin-sim.c (decode_dsp32alu_0): Drop the src0/src1 check for
615 BYTEOP1P, BYTEOP2P, and BYTEOP3P insns.
616
a9c3ef47
MF
6172011-03-23 Mike Frysinger <vapier@gentoo.org>
618
619 * machs.c (bf50x_dev, bf512_dev, bf516_dev, bf522_dev, bf526_dev,
620 bf533_dev, bf534_dev, bf537_dev, bf538_dev, bf561_dev, bf592_dev):
621 Change bfin_gpio addresses from f/g/h to 5/6/7.
622 (bfin_model_hw_tree_init): Add the bfin_gpio address base to 'a'.
623
9e6584c9
MF
6242011-03-17 Mike Frysinger <vapier@gentoo.org>
625
626 * configure.ac (AC_CHECK_FUNCS): Check for kill and pread.
627 * configure: Regenerate.
628 * config.in: Regenerate.
629 * interp.c (bfin_syscall): Check for HAVE_{KILL,PREAD} before using
630 kill or pread.
631
b5215db0
MF
6322011-03-15 Mike Frysinger <vapier@gentoo.org>
633
634 * Makefile.in (dv-bfin_gpio.o): New target.
635 * configure.ac (SIM_AC_OPTION_HARDWARE): Add bfin_gpio.
636 * configure: Regenerate.
637 * dv-bfin_gpio.c, dv-bfin_gpio.h: New files.
638 * machs.c: Include dv-bfin_gpio.h.
639 (bf50x_mem, bf51x_mem, bf52x_mem, bf531_mem, bf532_mem, bf533_mem,
640 bf534_mem, bf536_mem, bf537_mem, bf538_mem, bf561_mem, bf592_mem):
641 Delete GPIO memory stubs.
642 (bf50x_dev, bf512_dev, bf516_dev, bf522_dev, bf526_dev, bf533_dev,
643 bf534_dev, bf537_dev, bf538_dev, bf561_dev, bf592_dev): Add GPIO
644 peripheral devices.
645 (bfin_model_hw_tree_init): Hook up GPIO interrupts to SIC.
646
990d19fd
MF
6472011-03-15 Mike Frysinger <vapier@gentoo.org>
648
649 * bfroms/bf50x-0.0.h, bfroms/bf51x-0.0.h, bfroms/bf51x-0.1.h,
650 bfroms/bf51x-0.2.h, bfroms/bf526-0.0.h, bfroms/bf526-0.1.h,
651 bfroms/bf527-0.0.h, bfroms/bf527-0.1.h, bfroms/bf527-0.2.h,
652 bfroms/bf533-0.1.h, bfroms/bf533-0.2.h, bfroms/bf533-0.3.h,
653 bfroms/bf537-0.0.h, bfroms/bf537-0.1.h, bfroms/bf537-0.3.h,
654 bfroms/bf538-0.0.h, bfroms/bf54x-0.0.h, bfroms/bf54x-0.1.h,
655 bfroms/bf54x-0.2.h, bfroms/bf54x_l1-0.0.h, bfroms/bf54x_l1-0.1.h,
656 bfroms/bf54x_l1-0.2.h, bfroms/bf561-0.5.h, bfroms/bf59x-0.0.h,
657 bfroms/bf59x_l1-0.1.h, dv-bfin_cec.c, dv-bfin_ctimer.c,
658 dv-bfin_dma.c, dv-bfin_dmac.c, dv-bfin_ebiu_amc.c,
659 dv-bfin_ebiu_ddrc.c, dv-bfin_ebiu_sdc.c, dv-bfin_emac.c,
660 dv-bfin_eppi.c, dv-bfin_evt.c, dv-bfin_gptimer.c, dv-bfin_jtag.c,
661 dv-bfin_mmu.c, dv-bfin_nfc.c, dv-bfin_otp.c, dv-bfin_pll.c,
662 dv-bfin_ppi.c, dv-bfin_rtc.c, dv-bfin_sic.c, dv-bfin_spi.c,
663 dv-bfin_trace.c, dv-bfin_twi.c, dv-bfin_uart.c, dv-bfin_uart2.c,
664 dv-bfin_wdog.c, dv-bfin_wp.c, dv-eth_phy.c, gui.c,
665 linux-fixed-code.h, linux-targ-map.h, machs.c, Makefile.in: Fix style.
666
227d2658
MF
6672011-03-15 Robin Getz <robin.getz@analog.com>
668
669 * bfin-sim.c (decode_dsp32alu_0): Set AZ based on val for 16bit adds
670 and subs.
671
e3809a37
MF
6722011-03-15 Robin Getz <robin.getz@analog.com>
673
674 * bfin-sim.c (decode_macfunc): Move acc STOREs behind op != 3 check.
675
86d3d8de
MF
6762011-03-15 Robin Getz <robin.getz@analog.com>
677
678 * bfin-sim.c (decode_macfunc): New neg parameter. Set when the
679 high bit is set after extract_mult.
680 (decode_dsp32mac_0): Declare n_1 and n_0. Pass to the decode_macfunc
681 functions. Use these to update the AN bit.
682
9b7509d9
MF
6832011-03-15 Robin Getz <robin.getz@analog.com>
684
685 * bfin-sim.c (decode_dsp32mult_0): Declare v_i0 and v_i1. Pass to
686 the extract_mult functions. Include these when updating the V, VS,
687 and V_COPY bits.
688
bf416ccd
MF
6892011-03-15 Robin Getz <robin.getz@analog.com>
690
691 * bfin-sim.c (astat_names): New global bit array.
692 (decode_CC2stat_0): Delete local astat_name and astat_names.
693 (decode_psedodbg_assert_0): Move hardcoded offset into a variable.
694 Print out ASTAT bit values when checking an ASTAT register.
695
c9329594
MF
6962010-03-15 Robin Getz <robin.getz@analog.com>
697
698 * bfin-sim.c (extract_mult): Handle M_IU.
699
f4e33aa6
MF
7002011-03-05 Mike Frysinger <vapier@gentoo.org>
701
702 * Makefile.in, TODO, aclocal.m4, bfin-sim.c, bfin-sim.h,
703 bfroms/all.h, bfroms/bf50x-0.0.h, bfroms/bf51x-0.0.h,
704 bfroms/bf51x-0.1.h, bfroms/bf51x-0.2.h, bfroms/bf526-0.0.h,
705 bfroms/bf526-0.1.h, bfroms/bf527-0.0.h, bfroms/bf527-0.1.h,
706 bfroms/bf527-0.2.h, bfroms/bf533-0.1.h, bfroms/bf533-0.2.h,
707 bfroms/bf533-0.3.h, bfroms/bf537-0.0.h, bfroms/bf537-0.1.h,
708 bfroms/bf537-0.3.h, bfroms/bf538-0.0.h, bfroms/bf54x-0.0.h,
709 bfroms/bf54x-0.1.h, bfroms/bf54x-0.2.h, bfroms/bf54x_l1-0.0.h,
710 bfroms/bf54x_l1-0.1.h, bfroms/bf54x_l1-0.2.h, bfroms/bf561-0.5.h,
711 bfroms/bf59x-0.0.h, bfroms/bf59x_l1-0.1.h, config.in, configure,
712 configure.ac, devices.c, devices.h, dv-bfin_cec.c, dv-bfin_cec.h,
713 dv-bfin_ctimer.c, dv-bfin_ctimer.h, dv-bfin_dma.c, dv-bfin_dma.h,
714 dv-bfin_dmac.c, dv-bfin_dmac.h, dv-bfin_ebiu_amc.c, dv-bfin_ebiu_amc.h,
715 dv-bfin_ebiu_ddrc.c, dv-bfin_ebiu_ddrc.h, dv-bfin_ebiu_sdc.c,
716 dv-bfin_ebiu_sdc.h, dv-bfin_emac.c, dv-bfin_emac.h, dv-bfin_eppi.c,
717 dv-bfin_eppi.h, dv-bfin_evt.c, dv-bfin_evt.h, dv-bfin_gptimer.c,
718 dv-bfin_gptimer.h, dv-bfin_jtag.c, dv-bfin_jtag.h, dv-bfin_mmu.c,
719 dv-bfin_mmu.h, dv-bfin_nfc.c, dv-bfin_nfc.h, dv-bfin_otp.c,
720 dv-bfin_otp.h, dv-bfin_pll.c, dv-bfin_pll.h, dv-bfin_ppi.c,
721 dv-bfin_ppi.h, dv-bfin_rtc.c, dv-bfin_rtc.h, dv-bfin_sic.c,
722 dv-bfin_sic.h, dv-bfin_spi.c, dv-bfin_spi.h, dv-bfin_trace.c,
723 dv-bfin_trace.h, dv-bfin_twi.c, dv-bfin_twi.h, dv-bfin_uart.c,
724 dv-bfin_uart.h, dv-bfin_uart2.c, dv-bfin_uart2.h, dv-bfin_wdog.c,
725 dv-bfin_wdog.h, dv-bfin_wp.c, dv-bfin_wp.h, dv-eth_phy.c, gui.c,
726 gui.h, insn_list.def, interp.c, linux-fixed-code.h, linux-fixed-code.s,
727 linux-targ-map.h, machs.c, machs.h, proc_list.def, sim-main.h,
728 tconfig.in: New Blackfin port.