6502.org Forum  Projects  Code  Documents  Tools  Forum
It is currently Thu Nov 21, 2024 5:33 pm

All times are UTC




Post new topic Reply to topic  [ 66 posts ]  Go to page Previous  1, 2, 3, 4, 5  Next
Author Message
PostPosted: Thu Dec 16, 2021 9:05 am 
Offline
User avatar

Joined: Fri Nov 09, 2012 5:54 pm
Posts: 1431
12) A, the accumulator.

It is located East from "11) BCD correction" in the silicon.
Actually, BCD correction and A form one function block on the silicon,
with just the active region of one FET separating them.

The only way how data can enter A is through the BCD correction.

Conceptually, the A register cells work similar to what we had in "2) Y register":
The Bits are refreshed during PHI2,
and read/written during PHI1# =0 (what is different from PHI2 =1).

Except that A has two outputs: one to DB bus, and one to SB bus.

When looking at the very dense silicon layout,
it's hard to tell wether the SB<>DB transfer FET switches which connect SB bus to DB bus
should be put into the "12) A" page or the "13) DB<>ADH transfer switches" page of the schematics.

Attachment:
si6509_12_a.png
si6509_12_a.png [ 17.94 KiB | Viewed 1225 times ]

Attachment:
6509_12_a.png
6509_12_a.png [ 38.01 KiB | Viewed 1225 times ]


Top
 Profile  
Reply with quote  
PostPosted: Thu Dec 16, 2021 9:09 am 
Offline
User avatar

Joined: Fri Nov 09, 2012 5:54 pm
Posts: 1431
13) SB<>ADH transfer switches

SB<>ADH transfer switches are located East from A (the accumulator) in the silicon.
Actually, it is not easy to tell A, SB<>DB transfer switches and SB<>ADH transfer switches apart.

As the name says, SB<>ADH transfer FET switches connect SB bus and ADH bus,
where SB bus only is in the West half of the mill, and ADH bus only is in the East half of the mill.

Note, that the 4 internal bus systems ADL, ADH, DB, SB are precharged to 1 by FETs during PHI2.
Placement of the precharge FETs is very creative to save chip space,
so I had decided to put the precharge FETs into "13)" of the cheat sheet for increasing readability.
Note, that the precharge FET switches have a certain impedance when closed,
so I had interpreted them as "pullup resistors switched to VCC".

Also for increasing readability, I had decided to go with "ADL0..7" and "ADH8..15".
//As having "ADL0..7" for A0..7 and "ADH0..7" for A8..15 sure would have caused some confusion later.


Since we are at it:
East from the SB<>ADH transfer switches, we have the ADH constant generators.
Zero page access requires ADH to be $00.
Stack access requires ADH to be $01.
Interrupt vector fetch requires ADH to be $FF.

So we have one FET switching ADH8 to GND, controlled by '0>ADH8'.
And seven FETs switching ADH9..15 to GND, controlled by '0>ADH'.

Attachment:
si6509_13_transfer.png
si6509_13_transfer.png [ 19.75 KiB | Viewed 1225 times ]

Attachment:
6509_13_transfer.png
6509_13_transfer.png [ 34.26 KiB | Viewed 1225 times ]


Top
 Profile  
Reply with quote  
PostPosted: Thu Dec 16, 2021 9:12 am 
Offline
User avatar

Joined: Fri Nov 09, 2012 5:54 pm
Posts: 1431
14) PC, the program counter.

PC function block is located between "13) SB<>ADH transfer switches" and "15) data latch" in the silicon.

Actually, PCH counter cells (PC Bit 8..15) are East from "13) SB<>ADH transfer switches",
and PCL counter cells (PC Bit 0..7) are East from the PCH counter cells.
//Short form: PC8..15 left, PC0..7 right.

Note, that ADL precharge FETs are integral part of the ADH related PC counter cells.

We have the usual inverted/non_inverted carry chain,
it's just more complicated because PC makes creative use of carry lookahead mechanisms.

PC Bit 0 has a low_active carry input: PCLC#.
The 16 Bit PC carry chain breaks into three parts:8/4/4 Bits.

PC Bit 0..7 are linked together by ripple carry, that's 8 Bits.
The first carry lookahead mechanism uses PCLC# and PC Bit 0..7 for generating the high_active PC Bit 8 input carry.

PC Bit 8..11 are linked together by ripple carry, that's 4 Bits.
The second carry lookahead mechanism uses PC Bit 8 input carry and PC Bit 8..11 for generating the high_active PC12 input carry.

PC12..15 are linked together by ripple carry, that's 4 Bits.

Note, that the chip layout of PC Bit 0..7 counter cells resembles the mirrored layout of the PC Bit 8..15 counter cells
for saving chip space.

ADL\ADH bus (16 Bit) can read/write PCL\PCH (16 Bit),
DB bus (8 Bit) only can read PCL\PCH (2* 8 Bit).

Attachment:
si6509_14_pc.png
si6509_14_pc.png [ 47.31 KiB | Viewed 1225 times ]

Attachment:
si6509_14_pc_input_carry.png
si6509_14_pc_input_carry.png [ 9.25 KiB | Viewed 1225 times ]

Attachment:
si6509_14a_pc_cil.png
si6509_14a_pc_cil.png [ 18.82 KiB | Viewed 1225 times ]

Attachment:
si6509_14b_pc_cih.png
si6509_14b_pc_cih.png [ 17.97 KiB | Viewed 1225 times ]

Attachment:
6509_14_pc.png
6509_14_pc.png [ 175.01 KiB | Viewed 1225 times ]


Top
 Profile  
Reply with quote  
PostPosted: Thu Dec 16, 2021 9:13 am 
Offline
User avatar

Joined: Fri Nov 09, 2012 5:54 pm
Posts: 1431
15) data latch //plus ADH precharge FETs

Data latch is located East from the PC Bit 0..7 counter cells in the silicon.

DB is sampled with transparent latches during PHI1,
and in a 6502 the outputs of said latches would go directly to the D0..7 pad drivers.

In a 6502, D0..7 pads would be sampled with transparent latches during PHI2,
and the outputs of said latches would be switched during PHI1
either to DB bus, ADL bus, ADH bus, or to no bus at all.

But since we have a 6509, like in the 8501 the on_chip peripherals are
"creatively bolted" between "15) data latch" and the D0..7 drivers\buffers.

For more details, see here.

Attachment:
si6509_15_data_latch.png
si6509_15_data_latch.png [ 21.26 KiB | Viewed 1225 times ]

Attachment:
6509_15_data_latch.png
6509_15_data_latch.png [ 54.36 KiB | Viewed 1225 times ]


Top
 Profile  
Reply with quote  
PostPosted: Thu Dec 16, 2021 9:14 am 
Offline
User avatar

Joined: Fri Nov 09, 2012 5:54 pm
Posts: 1431
16) PHI1# driver

PHI1# driver is located a bit East from the A4 pad in the silicon.

It's an inverting super buffer, fed by PHI1, sending PHI1# through two metal traces
into "17) control signal latches\drivers".

IIRC the NMOS 6502 uses two smaller inverting super buffers instead,
each of them driving a PHI1# metal trace separately.

That part of the 6509 CPU core definitely is different from the NMOS 6502.

Attachment:
si6509_16_phi1#_driver.png
si6509_16_phi1#_driver.png [ 11.02 KiB | Viewed 1225 times ]

Attachment:
6509_phi1#_driver.png
6509_phi1#_driver.png [ 26.43 KiB | Viewed 1216 times ]



;---

It's the first time I have seen a pulldown FET used inside a super buffer,
and I wonder why the designers did it that way.

Attachment:
si6509_16_phi1#_driver_pulldown.png
si6509_16_phi1#_driver_pulldown.png [ 23.68 KiB | Viewed 1216 times ]


Last edited by ttlworks on Thu Dec 16, 2021 1:28 pm, edited 2 times in total.

Top
 Profile  
Reply with quote  
PostPosted: Thu Dec 16, 2021 9:17 am 
Offline
User avatar

Joined: Fri Nov 09, 2012 5:54 pm
Posts: 1431
17) control signal latches\drivers //actually 17a)..17f)

They are located East from "16) PHI1# driver" in the silicon, North from the mill.
And they are turning most of the outputs of the random logic area
into control signals for the mill.

17a) layout is a bit different from 17b)..17f) layout to make better use of chip space.

South from the mill, at the other end of the PolySilicon control signal traces,
there are FETs switching some of the control signals during PHI2,
and technically they belong to 17).

Control signals switched to GND during PHI2 (from West to East):
Y>SB, X>SB, SB>Y, SB>X,
SB>S, S>S,
DB>ADD, DB#>ADD, ADL>ADD, SB>ADD,
SB>A, A>SB, A>DB,
ADH>PCH, PCH>PCH, PCL>PCL, ADL>PCL.

Maybe there wasn't enough free chip space for switching some
of the other control signals to GND during PHI2, too.

Note, that all of the control signal latches\drivers are inverting,
except for ADD>SB7, which is non_inverting.
;
In the original MOS 6502 schematics, the input and output of the ADD>SB7
latch\driver is labelled 'ADD>SB7'.
To avoid further confusion, I had named the input 'ADD>SB7_'.

;---

The switches pulling control signals to GND during PHI2
at the other end of the PolySilicon traces just are a hardware trick
to make sure that the control signal really is low during PHI2,
to compensate for trace capacitance/resistance.
We already had seen such things in the 6530.

For control signals which wich are inactive when PHI1# =high OR PHI2 =high:
from the logic design point of view, PHI1# OR PHI2 looks like PHI1#,
so when trying to show just how things work we could throw
the PHI2 gating out of the equations.

Attachment:
si6509_17a_control_driver.png
si6509_17a_control_driver.png [ 10 KiB | Viewed 1225 times ]

Attachment:
si6509_17b_control_driver.png
si6509_17b_control_driver.png [ 19.77 KiB | Viewed 1225 times ]

Attachment:
si6509_17c_control_driver.png
si6509_17c_control_driver.png [ 62.71 KiB | Viewed 1225 times ]

Attachment:
si6509_17d_control_driver.png
si6509_17d_control_driver.png [ 23.21 KiB | Viewed 1225 times ]

Attachment:
si6509_17e_control_driver.png
si6509_17e_control_driver.png [ 66 KiB | Viewed 1225 times ]

Attachment:
si6509_17f_control_driver.png
si6509_17f_control_driver.png [ 17.91 KiB | Viewed 1225 times ]

Attachment:
6509_17_control_driver.png
6509_17_control_driver.png [ 514.98 KiB | Viewed 1225 times ]


Top
 Profile  
Reply with quote  
PostPosted: Thu Dec 16, 2021 9:19 am 
Offline
User avatar

Joined: Fri Nov 09, 2012 5:54 pm
Posts: 1431
18) P

What I called 'P' is located East from "17f) control signal latches\drivers" in the silicon.

It's the "front end" for reading/writing the Flags to/from the DB bus,
we could say it's what the "end user" sees as the status register.

Also, it contains an 8 input NOR gate, which checks if the DB bus is $00
for Z Flag evaluation. //DBZ# is 0, if DB bus is $00.

Also, it contains an inverter which turns the high_active ALU carry output ACR
into the low_active ACR# signal.

In the cheat sheet, I had used 7404 and 74125 type gates between the Flag outputs and the switches
connecting to the DB bus, but in reality it's more something like
"7405\7407 open collector inverters\buffers with pullup",
please keep this in mind when digging into the "illegal" NMOS 6502 instructions.

Attachment:
si6509_18_p.png
si6509_18_p.png [ 50.35 KiB | Viewed 1225 times ]

Attachment:
6509_18_p.png
6509_18_p.png [ 110.07 KiB | Viewed 1225 times ]


Top
 Profile  
Reply with quote  
PostPosted: Thu Dec 16, 2021 9:23 am 
Offline
User avatar

Joined: Fri Nov 09, 2012 5:54 pm
Posts: 1431
19) Flags

Flags are located North East from "18) P" in the silicon,
and technically they are integral parts of the random logic area.

Everything is pretty much standard, outputs of the Flags change during PHI1,
but note that the inputs and outputs of the Flags are low_active.

In addition to the Flags N, V, D, I, Z, C,
we also have a Flag labelled "POS" in the NMOS 6502 schematics.
It is not visible to the "end user", and it is used for detecting
a 256 Bytes page crossing during branch instructions.

;---

The way how the I Flag is set in the T6 cycle of a BRK\INT sequence
for masking/disabling the IRQ# interrupt isn't easy to spot:
The low_active output I# of the I Flag is generated by a FET\inverter
switching to GND plus a pullup resistor (FET).
;
Mid West in "27) random 3", we have another FET which switches I# to GND during T6.
The related signals are labeled 'I#', '23.C' (which is active during T6), '23.Z' (high_active I).
The trick is, that the two FETs switching I# to GND plus the pullup are forming a NOR gate.

BTW: It's not that unusual in a 6502 like core to have FETs in different areas of the silicon
connected by long traces, forming up a logic gate... considering how 'ADH>ABH#' is generated...

;---

It's nicely done how a falling edge at the CPS pad sets the V Flag.
//The falling edge detector sensing the CPS pad was done in a previous dissection.

Attachment:
si6509_19a_z.png
si6509_19a_z.png [ 17.98 KiB | Viewed 1225 times ]

Attachment:
si6509_19b_v.png
si6509_19b_v.png [ 35.17 KiB | Viewed 1225 times ]

Attachment:
si6509_19c_c.png
si6509_19c_c.png [ 15.73 KiB | Viewed 1225 times ]

Attachment:
si6509_19d_d.png
si6509_19d_d.png [ 12.65 KiB | Viewed 1225 times ]

Attachment:
si6509_19e_n.png
si6509_19e_n.png [ 11.54 KiB | Viewed 1225 times ]

Attachment:
si6509_19f_pos.png
si6509_19f_pos.png [ 17.69 KiB | Viewed 1225 times ]

Attachment:
si6509_19g_i.png
si6509_19g_i.png [ 16.16 KiB | Viewed 1225 times ]

Attachment:
6509_19_flags.png
6509_19_flags.png [ 312.15 KiB | Viewed 1225 times ]


Top
 Profile  
Reply with quote  
PostPosted: Thu Dec 16, 2021 9:25 am 
Offline
User avatar

Joined: Fri Nov 09, 2012 5:54 pm
Posts: 1431
20) Flag multiplexer

It is located South West from "19) Flags" in the silicon.

6502 features conditional branches.
"conditional" means testing if a specific Flag is 0 or 1.

It breaks down to a 4:1 multiplexer, with signals from the Flags N,V,Z,C at the data inputs.

At the two control inputs, we have Bit 7 and Bit 6 from the instruction Byte,
selecting which one of these 4 Flags is to be tested.

We have something like an XOR gate, which does invert/not_invert
the multiplexer output depending on Bit 5 from instruction Byte,
generating the signal BRN# which is low when the condition is met
and the branch should be taken.
Said XOR gate is for testing if the selected Flag is 0 or 1.

;---

That's how it conceptually works, except that the Flag outputs are low_active,
and that Bit 5..7 from the instruction Byte also arrive at 20) in low_active form.

Inverted instruction Bit 5 comes from "21) instruction register".
Inverted instruction Bits 6,7 are generated by the PLA from the outputs
of "21) instruction register".

Attachment:
si6509_20_flag_mux.png
si6509_20_flag_mux.png [ 28.22 KiB | Viewed 1225 times ]

Attachment:
6509_20_flag_mux.png
6509_20_flag_mux.png [ 96.72 KiB | Viewed 1225 times ]


Top
 Profile  
Reply with quote  
PostPosted: Thu Dec 16, 2021 9:27 am 
Offline
User avatar

Joined: Fri Nov 09, 2012 5:54 pm
Posts: 1431
21) instruction register

Instruction register is located North from "20) Flag multiplexer" in the silicon,
a bit South from the D0 pad.

Basically, it sends the instruction Byte in inverted and non_inverted form into the PLA,
also it sends Bit 5 of the instruction Byte in inverted form as signal 'I5A#'
to "20) Flag multiplexer".

In the original MOS 6502 schematics, we have transparent latches between the D0..7 pads
and the instruction register, sampling the instruction Byte from D0..7 during PHI2.

In the 6509, the designers had pulled a trick for saving chip space:
these latches are a hidden/integral part of the D0..7 input buffers,
but it's not obvios to spot that.

So I explicitly had inserted these latches in the input buffers in my cheat sheet,
because if you miss that they are there, your FPGA implementation of the 6509
most likely won't be working at all.

;---

Note the IBE# signal which controls the 8 logic gates at the input of the instruction register,
that's a mechanism to make the instruction register load $00 during the next instruction fetch,
ignoring the Byte from D0..7.

$00 is the BRK instruction, a software interrupt.

When "23) interrupt logic" has detected RES#, NMI#, or IRQ#,
it uses this mechanism for faking a BRK instruction,
tricking the rest of the CPU into actually executing a BRK sequence without incrementing PC
(to make sure that the already fetched instruction Byte is read again after a RTI),
the BRK sequence then fetches the interrupt vector with a little bit of help
offered by "23) interrupt logic".

It's another neat trick for saving some chip space.

;---

Integral part of the instruction register is the predecoder.
It connects to the outputs of the 8 logic gates which do that "BRK faking trick".

The predecoder is another little lump of logic gates,
checking the instruction Byte at the end of the instruction fetch cycle for two things:

Signal '1ByteOp#' is low, if the instruction has one Byte.
Since 6502 instructions take at least 2 cycles, the 6502 pipeline needs this signal
to prevent a PC increment in the second cycle of an instruction.

Signal '21.A' is low for instructions which take two cycles,
and where the ALU operation could be done in parallel with the next instruction fetch.
This signal goes to the sequencer.

Note, that the signals '1ByteOp#' and '21.A' are affected by that "BRK faking trick".

Attachment:
si6509_21_ir.png
si6509_21_ir.png [ 118.74 KiB | Viewed 1225 times ]

Attachment:
6509_21_ir.png
6509_21_ir.png [ 621.42 KiB | Viewed 1225 times ]


Top
 Profile  
Reply with quote  
PostPosted: Thu Dec 16, 2021 9:29 am 
Offline
User avatar

Joined: Fri Nov 09, 2012 5:54 pm
Posts: 1431
22a) sequencer for T0#, T1#

It's integral part of the random logic area, and not easy to spot.
It is located West from "21) instruction register" in the silicon.

It generates the low_active signals T0# and T1# for the PLA.

In the MOS 6502 schematics, we have two signals labelled 'T1' and 'T1#'.
Funny thing is, that they are not directiy related, but a different pair of shoes.
Means when inverting 'T1', what you get is very different from 'T1#', and vice versa.

To avoid further confusion, I had named 'T1' as 'T11' in my schematics.
T11 also goes through a non_inverting buffer to the SYNC pad.

The "T0#, T1# sequencer" is a bit tricky, and when just having it on your desk
without the circuitry around it, it doesn't become too obvious what it is doing.
So please take a look at "0) cheat sheet" to see, what connects to the
"T0#, T1# sequencer".

Signal 'METAL#' changes during PHI2 and tells that all of the cycles of an instruction
are complete... I think.

;---

22b) sequencer for T2#, T3#, T4# T5#

It is located West from the PLA in the silicon, a bit East from the A0 pad.

Basically, it's just a shift register with T11 at the input, feeding the low_active outputs T2#..T5# into the PLA.
Outputs change with PHI1.
Shifting is enabled when RDY# is low, but be aware that RDY# is not what you get when just inverting RDY.
METAL# sampled during PHI1 directly clears the shift register outputs, setting T2#..T5# to 1.

Again: for some more clues, see "0) cheat sheet".

;---

Note, that a BRK\INT sequence also requires state T6.

The T6 flipflop happens to be integral part of 23a), the NMI# related interrupt logic,
and it is triggered by the PLA.

Again: for some more clues, see "0) cheat sheet".

Attachment:
si6502_22a_seq0.png
si6502_22a_seq0.png [ 32.8 KiB | Viewed 1225 times ]

Attachment:
si6502_22b_seq2.png
si6502_22b_seq2.png [ 57.48 KiB | Viewed 1225 times ]

Attachment:
6509_22_seq.png
6509_22_seq.png [ 263.41 KiB | Viewed 1225 times ]


Top
 Profile  
Reply with quote  
PostPosted: Thu Dec 16, 2021 9:34 am 
Offline
User avatar

Joined: Fri Nov 09, 2012 5:54 pm
Posts: 1431
23) interrupt logic

It is part of the random logic area.

Part 23a) is located South from "22b) T2#..T5# sequencer" in the silicon,
a bit East from the A1 pad.
It contains the NMI# related logic and the T6 state flipflop.

Part 23b) is located North from "17a), 17b) control signal latches\drivers" in the silicon,
quite a bit East from the A2 pad.
It contains the RES# related logic,
and it generates the control signals for the ADL0..2 interrupt vector.
It also contains "the upper half" :roll: of the multifunction gate which generates ADH>ABH#,
the control signal responsible for transferring the contents of the ADH bus into
the ABH latches which are feeding A8..A15.

Part 23d) is located East from 23b) in the silicon.
It contains the IRQ# related logic,
it also generates the signal which shows up in the status register as "the B Flag".
//
//in the 6502, there is only one interrupt vector for both IRQ# and BRK.
//
//so the "end user" has to check the status register Byte which was pushed on the stack
//during the IRQ# or BRK sequence to find out if the cause of the interrupt
//either was IRQ# (B=0) or BRK (B=1).

Attachment:
si6502_23a_seq6.png
si6502_23a_seq6.png [ 45.81 KiB | Viewed 1225 times ]

Attachment:
si6509_23b_adl_vector.png
si6509_23b_adl_vector.png [ 32.21 KiB | Viewed 1225 times ]

Attachment:
si6509_23c_pla.png
si6509_23c_pla.png [ 43.07 KiB | Viewed 1225 times ]

Attachment:
si6509_23d_irq.png
si6509_23d_irq.png [ 22.41 KiB | Viewed 1225 times ]

Attachment:
6509_23_int.png
6509_23_int.png [ 340.33 KiB | Viewed 1225 times ]

Attachment:
6509_23_int_all.png
6509_23_int_all.png [ 73.33 KiB | Viewed 1225 times ]


;---

So... what about part 23c) ?
Part 23c) consists of a 2 input NOR gate and an inverter.
The NOR gate is fed by PLA term 26 "T5.INT", and the inverted RDY# signal.
Again: when inverting RDY#, what you get is very different from RDY.
PLA term 26 is active in state T5 during a BRK\RES#\NMI#\IRQ# sequence,
and it is Visual6502 Node 370.
;
If you take a look at the 6509 orientation picture:

Attachment:
6509_23c.png
6509_23c.png [ 1.19 KiB | Viewed 1225 times ]


Those little red dots floating around in the white "25) random 1" area... that's 23C).
And for the rest of the random logic area it's a lot worse, but we are getting there later.

;---

What the functional blocks of 23) are doing isn't that obvios if you have them
in isolated form on your desk.

But it becomes obvious in the documentation in "0) cheat sheet".


Top
 Profile  
Reply with quote  
PostPosted: Thu Dec 16, 2021 9:40 am 
Offline
User avatar

Joined: Fri Nov 09, 2012 5:54 pm
Posts: 1431
24) PLA

PLA, "programmable" logic array, it is located North from the random logic area in the silicon.
And if you ask me, the layout of the PLA basically looks pretty much like a part of the 6530 ROM area.

It's big, and it's easy to mess things up while dissecting it, so I broke it into 9 parts:
East to West 24a)..24i).

The instruction Byte from the instruction register [see 21)] enters the PLA at the East in inverted and non_inverted form.
T0# and T1# from the first sequencer [see 22a)] enter the PLA from the South East.
T2#..T5# from the second sequencer [see 22b)] enter the PLA from the West.
They connect to horizontal PolySilicon traces which form the rows of the PLA, connecting to inputs of the NOR gates.

Most of the colums are just NOR gates, means the PLA outputs are supposed to be high_active.
NOR gates are vertical metal traces with a pullup resistor (FET) at the North ends,
and with FETs switching to GND attached to them.
FETs switching to GND are controlled by some of the horizontal PolySilicon traces.
The South end of the vertical metal traces is the PLA output.

But in order to save chip space, the designers had routed three signals through otherwise dead PLA NOR gates:
24:IRQP#, 89:RDYP, 90:RES.

Three more of the NOR gates (or "PLA product terms") are not used: 107:, 114:, 123:.

And we have some product terms which are a bit different from the others:
RDY1# goes into 80:T0.BR,
108:Tx.PSH_PUL goes into 92:T2.ANY_ABS and 99:T3.ANY_ABS,
136:Tx.PSH_PUL_ goes into 145:Tx.IMPL together with I0 from the instruction register.

The names for the product terms are from the original MOS schematics with the ROR bug,
that's ROR instructions missing, so don't wonder that the word "ROR" doesn't show up in them.

Now for the notation I have used for the product terms in my schematics:
'101:T4.IND_Y' means that product term 101 is active (high) during state T4, for addressing mode 'indirect Y'.
Tx means, that a product term is valid for all of the states.
//Note, that the PLA does not check for state T6, T6 is handled in the random logic area.

In the MOS 6502 schematics, the designers deliberately had counted the product terms from West to East,
starting with '1'.
Deliberately means, that they had included the three signals 24:IRQP#, 89:RDYP, 90:RES which
technically are just routed through the PLA as product terms, despite that they are no PLA product terms.
And they also had included the vertical GND metal traces of the PLA into the count, that's:
7:GND, 23:GND, 41:GND, 59:GND, 79:GND, 100:GND, 117:GND, 135:GND.

;---

I checked twice, and I think that my schematic for the PLA is correct,
but you better check if these 3000+ spots are with or without a FET again.

Speaking of it, now for the bonus material for those who might want to code something
like a little C program which highlights which PLA term is active in the instruction table.

If you take my PLA schematic, and rotate it clockwise by 90°, you notice from left to right:
one row of dots is red, 4 rows of dots are yellow, 4 rows of dots are yellow again, and so on.
A dot means, that a FET switching to GND is present in this location.

Now for a list of manually generated (so you better check) hexadecimal numbers.
One number per line in the text file, which stands for one PLA product term,
when converting the hexadecimal number to binary:
a binary '1' means FET present, a binary '0' means no FET there.
//Binary number is right adjusted, and the "special" product terms have a comment attached to the hexadecimal number.

Point is, that these hexadecimal numbers were my intermediate step between dissecting the silicon and drawing the schematic.

Attachment:
24_pla.txt [1.81 KiB]
Downloaded 57 times


Plus a text file from Frank with the names of the product terms.

Attachment:
MOS650x_decode_rom.vh.txt [4.53 KiB]
Downloaded 45 times


;---

Soptted 14 cases where two PLA product terms generate identical results:
Code:
 51:T3.IND_Y     =   2:T3.IND_Y
 61:Tx.ROLx_ASLx = 121:Tx.ROLx_ASLx
 62:T5.JSR       = 116:T5.JSR
 64:T0.TYA       =   5:T0.TYA
 68:T0.TXA       =  11:T0.TXA
101:T4.IND_Y     =  45:T4.IND_Y
102:T3.ABS_X_Y   =  47:T3.ABS_X_Y
106:Tx.JMP       =  34:Tx.JMP
119:T3.PULA_PULP =  29:T3.PULA_PULP
127:T1.ADC_SBC   =  66:T1.ADC_SBC
128:T0.BIT       =  75:T0.BIT
130:T4.RTI       =  43:T4.RTI
136:Tx_PSH_PUL   = 108:Tx_PSH_PUL
142:T4.ABS_X_Y   =  77:T4.ABS_X_Y


;---

Attachment:
si6509_24a_pla.png
si6509_24a_pla.png [ 25.47 KiB | Viewed 1224 times ]

Attachment:
si6509_24b_pla.png
si6509_24b_pla.png [ 35.36 KiB | Viewed 1224 times ]

Attachment:
si6509_24c_pla.png
si6509_24c_pla.png [ 38.33 KiB | Viewed 1224 times ]

Attachment:
si6509_24d_pla.png
si6509_24d_pla.png [ 39.31 KiB | Viewed 1224 times ]

Attachment:
si6509_24e_pla.png
si6509_24e_pla.png [ 44.35 KiB | Viewed 1224 times ]

Attachment:
si6509_24f_pla.png
si6509_24f_pla.png [ 48.11 KiB | Viewed 1224 times ]

Attachment:
si6509_24g_pla.png
si6509_24g_pla.png [ 36.48 KiB | Viewed 1224 times ]

Attachment:
si6509_24h_pla.png
si6509_24h_pla.png [ 39.15 KiB | Viewed 1224 times ]

Attachment:
si6509_24i_pla.png
si6509_24i_pla.png [ 36.84 KiB | Viewed 1224 times ]

Attachment:
6509_24_pla.png
6509_24_pla.png [ 143.21 KiB | Viewed 1224 times ]


Top
 Profile  
Reply with quote  
PostPosted: Thu Dec 16, 2021 9:51 am 
Offline
User avatar

Joined: Fri Nov 09, 2012 5:54 pm
Posts: 1431
Ok, now for the rest of the random logic area.

As we already have seen in "23) interrupt logic",
the logic gates in that area are grouped together for maximal compactness,
not for making sense to the human brain.

So I had two choices:

Either to stick with the workflow from "23) interrupt logic",
what means trying to identify functional blocks and to cut them out of the silicon.
But chances for losing overview and making mistakes sure would increase exponentially
while doing this.

Or to first break down the whole area into a transistor level schematic
and to sort things out later.
But when having a transistor level schematic of the whole area,
it would be too big to keep overview either,
and it simply won't fit on one page in my schematics editor.

;---

So the decision was to break the random logic area into 4 parts,
from West to East that's 25)..28).

Then to make a transistor level schematic for each part,
what of course would cut through some of the logic gates,
for instance the FETs of the NOR gate generating the METAL# signal
show up on different pages.

Then to convert the 4 transistor level schematics separately to 4 logic gate schematics.
Then to clean the schematics up a bit while trying to simplify the logic,
like replacing "a NOR gate plus an inverter attached to its output" to an "OR gate" and such...
or eliminating two inverters in a row.

;---

25) random 1

Attachment:
si6509_25_random1.png
si6509_25_random1.png [ 75.54 KiB | Viewed 1222 times ]


;---

26) random 2

Attachment:
si6509_26_random2.png
si6509_26_random2.png [ 136.68 KiB | Viewed 1038 times ]


;---

27) random 3

Attachment:
si6509_27_random3.png
si6509_27_random3.png [ 174.53 KiB | Viewed 1222 times ]


;---

28) random 4

Attachment:
si6509_28_random4.png
si6509_28_random4.png [ 293.79 KiB | Viewed 1222 times ]


;---

Schematics for 25)..28) are really big, so I'm adding them as a ZIP.
Attachment:
random1_4_schematics.zip [1.63 MiB]
Downloaded 38 times


Last edited by ttlworks on Mon Feb 07, 2022 9:42 am, edited 2 times in total.

Top
 Profile  
Reply with quote  
PostPosted: Thu Dec 16, 2021 9:58 am 
Offline
User avatar

Joined: Fri Nov 09, 2012 5:54 pm
Posts: 1431
29) random 0

Eventually, this was the attempt to mount these 4 parts "random 1..4" together,
followed by some more cleaning and simplifying.

The final result with comments was cleaned up again in "0) cheat sheet".

Attachment:
6509_29_schematics.zip [885.34 KiB]
Downloaded 14 times


;---

In the MOS 6502 schematic, the PLA terms were not sorted by number,
but "creatively grouped" by function or such.

For making the schematic readable at all, I had decided to do the same,
but this still wasn't enough.

To make it readable enough, it was necessary to have product terms
show up more than once.

Means, if you see a signal trace which comes out of the PLA box,
and there is a little "stub" to said trace pointing to the left:
when searching where the PLA term shows up again in the schematic,
it is supposed to show up again to the left.

After you (hopefully) found it somewhere at the left,
you have a signal trace with a little "stub" which is supposed
to point to the right.
If you have bad luck, it also has another little "stub" pointing to the left _again_.

;---

To answer your next question:

The MOS 6502 schematic had the ROR bug, and it only showed a very big (and very confusing)
lump of logic gates for the random logic area, with long and confusing connections,
and with no comment on whatsoever about why the designers had built it that way,
and what every part does.

So it wasn't quite useful for this dissection, it just had added to the confusion.
For instance, if you have a signal named "foo" and another signal named "foo#" in these schematics,
what you get when inverting "foo" is different from "foo#", vice versa.

//That said, labelling a signal "RDY#" like in the original schematics wasn't a good idea after all.


Last edited by ttlworks on Tue Jun 18, 2024 6:34 am, edited 2 times in total.

Top
 Profile  
Reply with quote  
Display posts from previous:  Sort by  
Post new topic Reply to topic  [ 66 posts ]  Go to page Previous  1, 2, 3, 4, 5  Next

All times are UTC


Who is online

Users browsing this forum: Google [Bot] and 30 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: