Page 1 of 1
					
				About M68000 signals
				Posted: Tue Jul 06, 2010 9:38 am
				by mickagame
				I have a question about M68000 input signals.
For example IPL0, IPL1 ...
Imagine that you set IPL0 and you unset it before the end of the current opcode.
The interrupt will be cancelled?
Thame thing for BUSREQ and other input signals.
			 
			
					
				
				Posted: Tue Jul 06, 2010 5:12 pm
				by Chilly Willy
				That's all described in the manual, which is available online for free. You can find it darn near anywhere. I suggest you read it. It also gives you the timings for instructions, and info the number of read and write cycles done per instruction.
The bus section described all the signals, as well as the timings for hold on signals before they are considered valid.
Just google for it.
			 
			
					
				
				Posted: Wed Jul 07, 2010 5:51 am
				by HardWareMan
				I just clarified: See M68000 User Manual. Because there is M68000 Programmers Manual, where signals and timings are not described.
			 
			
					
				
				Posted: Wed Jul 07, 2010 8:05 am
				by mickagame
				Yes, that's why i couldn't see this timings.
Thank you very much for your help.
			 
			
					
				
				Posted: Wed Jul 07, 2010 8:53 pm
				by Chilly Willy
				HardWareMan wrote:I just clarified: See M68000 User Manual. Because there is M68000 Programmers Manual, where signals and timings are not described.
Yeah. Motorola published one programming reference for the "family", and then user manuals for each individual chip that covered the hardware and any differences to the main spec. So you'll find user manuals for the 68000, 68020, 68030, 68851, etc, but just one Programming Environment Manual covering all aspects of programming the 680x0 family processors.
 
			
					
				
				Posted: Fri Jul 09, 2010 7:44 am
				by mickagame
				The 68K needs, in best case, 4 clocks period ta read a byte, but if memory have latency the read cycle could be longer (cause of DTACK wait).
Does the latency of ram/rom has been measured on real sega genesis?
			 
			
					
				
				Posted: Fri Jul 09, 2010 8:06 am
				by HardWareMan
				mickagame wrote:Does the latency of ram/rom has been measured on real sega genesis?
Here. Also, I know that 190ns ROM works very unstable (I guess ROM must be quicker than 110ns).
 
			
					
				
				Posted: Fri Jul 09, 2010 8:21 am
				by mickagame
				In NTSC mode, a system clock is 18.625 ns long.
So we have 68k clock = 7 * 18.625 = 130 ns long.
If latency is longer than 130 ns, 68k run to slow and read/write cycle are longer ...
			 
			
					
				
				Posted: Fri Jul 09, 2010 7:05 pm
				by Chilly Willy
				It doesn't run slow - the Genesis uses a "standard" DTACK timing that is either met by roms, or isn't. Roms that meet the timing all work the same - roms that don't will crash when data isn't read correctly due to too fast timing on the DTACK. The Genesis is not capable of changing the timing of the DTACK for carts. If a cart needed special timing, it would have to use an address space where the Genesis doesn't assert the DTACK, then generate its own DTACK with the proper timing. No one does that.
			 
			
					
				
				Posted: Sat Jul 10, 2010 5:31 am
				by HardWareMan
				Chilly Willy wrote:It doesn't run slow - the Genesis uses a "standard" DTACK timing that is either met by roms, or isn't. Roms that meet the timing all work the same - roms that don't will crash when data isn't read correctly due to too fast timing on the DTACK. The Genesis is not capable of changing the timing of the DTACK for carts. If a cart needed special timing, it would have to use an address space where the Genesis doesn't assert the DTACK, then generate its own DTACK with the proper timing. No one does that.
Right. According to this picture:

According to 
M68000UM:
M68000UM wrote:STATE 0 The read cycle starts in state 0 (S0). The processor places valid function codes on FC0–FC2 and drives R/W high to identify a read cycle.
STATE 1 Entering state 1 (S1), the processor drives a valid address on the address bus.
STATE 2 On the rising edge of state 2 (S2), the processor asserts AS and UDS, LDS, or DS.
STATE 3 During state 3 (S3), no bus signals are altered.
STATE 4 During state 4 (S4), the processor waits for a cycle termination signal (DTACK or BERR) or VPA, an M6800 peripheral signal. When VPA is asserted during S4, the cycle becomes a peripheral cycle (refer to Appendix B M6800 Peripheral Interface). If neither termination signal is asserted before the falling edge at the end of S4, the processor inserts wait states (full clock cycles) until either DTACK or BERR is asserted.
STATE 5 During state 5 (S5), no bus signals are altered.
STATE 6 During state 6 (S6), data from the device is driven onto the data bus.
STATE 7 On the falling edge of the clock entering state 7 (S7), the processor latches data from the addressed device and negates AS, UDS, and LDS. At the rising edge of S7, the processor places the address bus in the highimpedance state. The device negates DTACK or BERR at this time.
This is fastest possible DTACK negotiation for M68000.