6502.org Forum  Projects  Code  Documents  Tools  Forum
It is currently Sat Nov 23, 2024 7:53 am

All times are UTC




Post new topic Reply to topic  [ 6 posts ] 
Author Message
PostPosted: Sun Mar 01, 2015 6:09 pm 
Offline

Joined: Mon Mar 25, 2013 4:43 pm
Posts: 15
Location: Arizona
I'm still unclear on exactly when to use a buffer or a latch, or a transceiver in a typical 6502 design. I don't really understand the difference between a buffer or latch, or how they work. Can some of you smart experienced guys give a rookie a primer? :oops:


Top
 Profile  
Reply with quote  
PostPosted: Sun Mar 01, 2015 6:35 pm 
Offline
User avatar

Joined: Thu Dec 11, 2008 1:28 pm
Posts: 10986
Location: England
In a very small design you probably don't need any of them, but:
- a buffer will add drive to a signal. You'd use one when you are driving a lot of loads, or a long distance, or both, and your signal is unidirectional, like an address bus or the clock. You might use a buffer to delay a signal but that's not robust and needs care.
- a tristate buffer acts as a buffer and can also not drive the output (that is, let the output be driven by something else.) This is good for time-sharing a bus, for example the CPU needs to drive the addresses of a RAM chip, and so does the video chip. (But not both at the same time.) Both drivers can use a tristate buffer to drive a shared bus.
- a transceiver acts as a bidirectional buffer: it drives in one direction or the other, depending on a control input. That's useful for a long distance or highly loaded data bus, where the CPU might need to read or write data to the RAM
- a latch has a clock input and can hold a value. One use is to hold the top 8 bits of the address value in a 65816 system, where the databus drives this value for just the first half of a clock cycle, and then reverts to normal bidirectional data mode for the second half.

For a simple design, see http://searle.hostei.com/grant/6502/Simple6502.html

The later CMOS versions of the 6502 have pretty high drive, and we rarely build multi-board RAM systems these days, so buffering of signals is done less than it used to be.


Top
 Profile  
Reply with quote  
PostPosted: Sun Mar 01, 2015 7:02 pm 
Offline
User avatar

Joined: Thu May 28, 2009 9:46 pm
Posts: 8507
Location: Midwestern USA
Good synopsis, Ed.

Since you mentioned use of a latch with the 65C816 to capture the bank bits, I will mention that a transceiver is also used on the data bus so that the latter itself does not see the bank bits during Ø2 low. It appears that this is an essential requirement if any of the WDC periperhals (6521, 6522 and 6551) are part of the machine.

_________________
x86?  We ain't got no x86.  We don't NEED no stinking x86!


Top
 Profile  
Reply with quote  
PostPosted: Mon Mar 02, 2015 1:18 am 
Offline
User avatar

Joined: Fri Dec 11, 2009 3:50 pm
Posts: 3367
Location: Ontario, Canada
BigEd wrote:
You might use a buffer to delay a signal but that's not robust and needs care.
Right -- using a buffer to delay a signal is not a robust solution (because the amount of delay is variable, rather than exactly predictable). Hope you don't mind me clarifying, Ed. :)

BigDumbDinosaur wrote:
It appears that this is an essential requirement if any of the WDC periperhals (6521, 6522 and 6551) are part of the machine.
If you're not sure, perhaps your post would've been better framed as a question, BDD. Can you explain why any peripherals, 65xx or otherwise, mustn't see the bank bits which an '816 outputs on the data bus during Ø2 low? Although 65xx peripherals are somewhat quirky in that they need their address inputs, chip selects and R/W valid upon the start of Phase 2, that's irrelevant to goings-on of the data bus.

cheers,
Jeff

_________________
In 1988 my 65C02 got six new registers and 44 new full-speed instructions!
https://laughtonelectronics.com/Arcana/ ... mmary.html


Top
 Profile  
Reply with quote  
PostPosted: Mon Mar 02, 2015 2:58 am 
Offline
User avatar

Joined: Thu May 28, 2009 9:46 pm
Posts: 8507
Location: Midwestern USA
Dr Jefyll wrote:
BigDumbDinosaur wrote:
It appears that this is an essential requirement if any of the WDC periperhals (6521, 6522 and 6551) are part of the machine.

If you're not sure, perhaps your post would've been better framed as a question, BDD. Can you explain why any peripherals, 65xx or otherwise, mustn't see the bank bits which an '816 outputs on the data bus during Ø2 low? Although 65xx peripherals are somewhat quirky in that they need their address inputs, chip selects and R/W valid upon the start of Phase 2, that's irrelevant to goings-on of the data bus.

During the 65C816's Ø2 low cycle, and as soon as the address is valid (VDA || VPA is true), selection of a peripheral device is possible. If, say, a 65C22 is selected during what is a write cycle, it isn't in the high-Z state and hence will see the bank bits as data. The timing diagram doesn't really make it clear as to whether such a condition is an issue. Use of the bus transceiver as depicted on page 46 of the 65C816 data sheet would assure that the 'C22 can't be confused by the bank bits. Hence my use of "It appears..."

This should not be a matter of concern with peripheral silicon that has separate /CS, /OE and /WE control inputs, as the latter two can be gated by Ø2 so the device doesn't connect to the data bus when Ø2 is low. That is how I arranged it in POC.

_________________
x86?  We ain't got no x86.  We don't NEED no stinking x86!


Top
 Profile  
Reply with quote  
PostPosted: Mon Mar 02, 2015 8:23 am 
Offline
User avatar

Joined: Fri Dec 11, 2009 3:50 pm
Posts: 3367
Location: Ontario, Canada
BigDumbDinosaur wrote:
The timing diagram doesn't really make it clear as to whether such a condition is an issue. Use of the bus transceiver as depicted on page 46 of the 65C816 data sheet would assure that the 'C22 can't be confused by the bank bits. Hence my use of "It appears..."

This should not be a matter of concern with peripheral silicon that has separate /CS, /OE and /WE control inputs, as the latter two can be gated by Ø2 so the device doesn't connect to the data bus when Ø2 is low.
Now I see what you're getting at. :) You're contrasting the Ø2 and R/W interface used on 65xx peripherals with the /RD and /WR (aka /OE and /WE) arrangement used on many non-65xx devices. And it's the peripheral datasheet you need to be looking at, not the '816 datasheet.

It's true there'd be a problem if a peripheral device connected to the data bus when the '816 CPU's Ø2 is low. And, as you say, with peripheral devices featuring the /RD & /WR interface the problem can be avoided by gating those signals with Ø2 (externally, as on the POC).

The same principle applies with 65xx peripherals. However, with 65xx devices the gating is internal -- no external gates are required. They will not input or output data when Ø2 is low. The 65c22 datasheet spills the beans.
Attachment:
File comment: from page 46 of WDC's 65c22 datasheet
65c22 read-write timing.gif
65c22 read-write timing.gif [ 19.52 KiB | Viewed 1531 times ]
Attachment:
w65c22 data sheet 2010 Sep.pdf [727.44 KiB]
Downloaded 90 times

_________________
In 1988 my 65C02 got six new registers and 44 new full-speed instructions!
https://laughtonelectronics.com/Arcana/ ... mmary.html


Top
 Profile  
Reply with quote  
Display posts from previous:  Sort by  
Post new topic Reply to topic  [ 6 posts ] 

All times are UTC


Who is online

Users browsing this forum: No registered users and 13 guests


You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot post attachments in this forum

Search for:
Jump to: