So It's been a while. Been doing some RF projects for ham radio the last months, and been a bit out of the loop with the microcomputers. Until my interest was sparked by a piece of test gear:
I got a logic analyzer! Thurlby (Tti) LA4800 48CH. logic analyzer!
It was fairly cheap, even though it lacks the probes. The thurlby analyzers uses these pods with IDC connectors, which basically just contains some input protection and some buffers. It says in the manual that you really just COULD connect wires directly to the input connectors, but there is NO input protection what so ever. they feed right into some standard 7400-logic buffers and some SIP resistors for pullup(down?), so if you feed it a smidgen more than 5V, you burn those (at best). Probes are coming along nicely, probably done by tomorrow (might make an update on them).
The interface is really nice, it's intuitive, took me ½ an hour without manual to get a basic understanding of it. It does both timing and state analysis, and also has an external clock input.
It comes with some nice sets of default settings; 8 bit computer
being one of the better. Pictured is some banks of test data it had.
The hardware seems dated 1992- design is probably late 80's early 90's.
The main board is almost entirely trough-hole, the only smd stuff being the LCD drivers on the module.
Most chips are 7400-series, with some nice big RAM for the datalogging. processor(s), yes, it has two, each associated with an eprom and some more ram; I'm suspecting one set is purely for the RS432 communications. Anyway, processors are Hitachi HD6303 processor.
The display has wonderful contrast, even contrast and brightness setting.
Truly a very neat bit of gear.
A blog to follow my endeavors into digital electronics, DIY microcomputers, retrocomputing and more!
Viser opslag med etiketten digital electronics. Vis alle opslag
Viser opslag med etiketten digital electronics. Vis alle opslag
torsdag den 1. januar 2015
onsdag den 15. oktober 2014
New project!
So, the z80 system 2 project being on hold until i get a functioning EPROM burner, I've moved forward on another project: The COSMAC ELF.
Though I've made some hardware mods, it is functionally equivalent of the original ELF. My mods include:
- Changing the HEX display to binary LED's; way cheaper.
This mod was actually suggested in the original article.
- Changed the two 4 bit 2101 RAM's for eight 1 bit 2102 ones.
I had them lying around and besides the "width" they're very similar. Furthermore, they're 1977 vintage - adds something to the design.
- Sprung for another layout, not wirewrap
Once again, I'm out of wrap wire, and I kinda wanted it to have more of a Altair 8800 / MIPS 8080 kinda look.
Here it is:
Though I've made some hardware mods, it is functionally equivalent of the original ELF. My mods include:
- Changing the HEX display to binary LED's; way cheaper.
This mod was actually suggested in the original article.
- Changed the two 4 bit 2101 RAM's for eight 1 bit 2102 ones.
I had them lying around and besides the "width" they're very similar. Furthermore, they're 1977 vintage - adds something to the design.
- Sprung for another layout, not wirewrap
Once again, I'm out of wrap wire, and I kinda wanted it to have more of a Altair 8800 / MIPS 8080 kinda look.
Here it is:
The 8 chips with dual round indents are the RAM.
I have redrawn the schematic into a more reader friendly form than the original, spreading it over 6 pages:
1) CPU and clock
2A) Original RAM
2B) My RAM
3) I/O logic
4) Display
5) Input
6) CPU control
Makes it much easier to debug and alter.
Anyway, so far, I've wired the processor control and power.
Buses are to come.
Etiketter:
1802,
8-Bit,
8bit,
COSMAC ELF,
CPU,
digital electronics,
DIY,
diy computer,
homemade computer,
Microcomputer,
retrocomputing
tirsdag den 30. september 2014
Diode matrix ROM for the Z80, or: How a silly, not-so optimized idea became a main design choice.
Ok, so the phase one hardware design for the z80 system B is almost done. Even started on expanding, but I would like to have it running first. But alas: having no EPROM's, and no burner for them, i had to think of something for a complete hardware test. So i decided to code three small program snips into a diode matrix ROM for it.
What a beauty! I've expanded the design (see last post) for 32 bytes, using 2 74154 4-16 decoders, and then feeding the lower 4 addresses into those. the next two addresses are fed to a 2-4 decoder, whose 1 and 2 output enables either chip 1 or 2.
The design of the diode matrix itself was a bit tricky. Most designs needs either multiple boards, or 3d arrays of wires, but eventually, i landed on having each trace (32 of them) for each line run all the length of the left half of the board. then, soldering tin/copper wire across the top of the board, and connecting those to the data lines, with pull ups. the result is rather neat, in its own right.
The bytes are read upwards, meaning that A0 is the lowest row, and so on. A diode indicates a 0, while a missing diode is 1. This is stupid, in terms of saving diodes, since 00 is used more often than FF, but yeah. Still needs some bytes, though, i ran out of diodes.
It should be able to mimic a 2716, or any device, really. I may need a tri-state buffer on DATA bus, and have the gate tied to /CS, to keep the bus floating from the pull ups. We'll see.
Once again, the sample programs are some counters and stuff i found on Donn Stewart's z80 page. I still haven't gotten around programming yet.
What a beauty! I've expanded the design (see last post) for 32 bytes, using 2 74154 4-16 decoders, and then feeding the lower 4 addresses into those. the next two addresses are fed to a 2-4 decoder, whose 1 and 2 output enables either chip 1 or 2.
The design of the diode matrix itself was a bit tricky. Most designs needs either multiple boards, or 3d arrays of wires, but eventually, i landed on having each trace (32 of them) for each line run all the length of the left half of the board. then, soldering tin/copper wire across the top of the board, and connecting those to the data lines, with pull ups. the result is rather neat, in its own right.
The bytes are read upwards, meaning that A0 is the lowest row, and so on. A diode indicates a 0, while a missing diode is 1. This is stupid, in terms of saving diodes, since 00 is used more often than FF, but yeah. Still needs some bytes, though, i ran out of diodes.
It should be able to mimic a 2716, or any device, really. I may need a tri-state buffer on DATA bus, and have the gate tied to /CS, to keep the bus floating from the pull ups. We'll see.
Once again, the sample programs are some counters and stuff i found on Donn Stewart's z80 page. I still haven't gotten around programming yet.
lørdag den 6. september 2014
Z80 System B update
So, the only thing lacking hardwarewise on the Z80 system I'm building, is the I/O. Once more, I was very inspired by Donn Stewarts z80 project in my port control logic, though I've made a connector for an external "terminal".
As you see, the "terminal" is really just two ports of LEDS as output and slide switches as input. The cable goes to a 40 pin DIL ribbon connector and socket, to port select and latching, etc.
As you see, the "terminal" is really just two ports of LEDS as output and slide switches as input. The cable goes to a 40 pin DIL ribbon connector and socket, to port select and latching, etc.
This is the interface board, using the 74LS139 as address decoder/port selector, and 74LS244 for input buffers, 74LS373 for display latches. Still needs wiring.
And Wouldn't you know: The board cracked! when i was scoring the rectangular cutouts for the switches! The pcb material were.. not good; had a consistency as wet crackers, and flaked like slate, meaning when it cracked (the entire bottom right quarter) it sliced the palm of my hand right up! but i was able to fix it (the board, that is; the hand takes care of itself) by means of screwing on a little piece of pcb on the underside, and solder some of the traces back. Holds quite well.
Etiketter:
8-Bit,
8bit,
control panel,
digital electronics,
DIY,
diy computer,
homemade computer,
Z80,
Z80 system B
torsdag den 4. september 2014
Z80 computer update
It ALMOST lives. I'm currently working on the IO interface, which is just some latches and buffer logic with two ports of 8 LEDS and 8 switches. This "terminal" is connected via rainbow ribbon to a socket on the IO board:
The board is yet to be wired, which will be done in the style of the memory board.
The system as of writing looks like this:
The card labeled "memory card" is the memory card, and likewise with the others. You probably guessed that, though. I haven't made/bought the PSU yet, so it is powered by a variable psu, adjusted with a DMM. The ribbon is supposed to go to an angled front plate.
The board is yet to be wired, which will be done in the style of the memory board.
The system as of writing looks like this:
The card labeled "memory card" is the memory card, and likewise with the others. You probably guessed that, though. I haven't made/bought the PSU yet, so it is powered by a variable psu, adjusted with a DMM. The ribbon is supposed to go to an angled front plate.
lørdag den 30. august 2014
Memory circuit wired
This is the memory card for my Z80 system. It contains a single 8x2k SRAM, the 6116-2, one of my favorite SRAM's, because its name is a palindrome. A 2716 EPROM of same size (and pin compatible, by the way) is used as system ROM. Address decoding for chip select with a 74139. Memory decoding entirely after Donn Stewart's Z80 computer. A more refined point-to-point wiring technique than with the indicator card, and i think it's really neat! Maybe even more so than wire-wrap.
Using the same wire to make little ties for the wire bundles.
For this method, start by wiring power, then control logic, and THEN DATA and ADDRESS buses, as you see, they are the ones who takes up space. Make sure that the wires are approximately the right length to be routed, and then after soldering of a bundle, begin "neating" with wire ties, either free floating or though holes in the PCB. excess length can be huddled up at one end (here, at the connector).
fredag den 29. august 2014
The indicator card done
The indicator card made, with a different construction technique, since i wanted to exercise different prototyping methods for digital hardware. Okay, okay; I ran out of wire wrap wire.
Thiss is 26 AWG wire, thicker than W-W. wire, but not much. Still so thin the insulation goes through the standard PCB holes. gives a good deal of strain relief, and allows for use as wire binders.
Not much more to tell about this:
Thiss is 26 AWG wire, thicker than W-W. wire, but not much. Still so thin the insulation goes through the standard PCB holes. gives a good deal of strain relief, and allows for use as wire binders.
Not much more to tell about this:
The processor card
The processor card is basically just a z80 with buffered buses and some functions. A clean reset circuit, and two clocks are on board as well. A manual step clock, and a slow clock ( a couple of Hz). This board, the clock and reset in particular, is inspired by CPUville's homebrew z80 project. This also served as the inspiration for this project.
This is the card. The red % button is the reset, and the toggle switch is the manual clock. the header matrix to the left of the processor is to select the clock via jumper, so you don't accidentally switch on two clocks at the same time.
Wire color code: RED: When it was closest. BLUE: When that was closest. Power is mainly routed on the solder side.
Computer base and indicator card!
OK, so these come pretty close one after another, since i'm actually past these steps, but behind on making a blog about it.
Well, the base is made, as mentioned from wood, and the Indicator card is made.
Well, the base is made, as mentioned from wood, and the Indicator card is made.
Well this is the indicator /bus display card. It is nothing fancy, just a binary readout of the entire bus. Upper row are DATA (7-0 in reading order), the two rows are ADDRESS(15-0), and the lower six are: Reset, Clock, Memrq, IOrq, RD and WR.
the four chips, 74LS241, is simply set up as noninverting buffers, which has some problems, since most of the control signals are active low. Good thing that won't confuse me when this machine doesn't do a thing!
Here be the base of the computer, the two cards installed. The dip socket on the bus card is to access the data bus, since i got the idea of wanting a little plug with pull-down resistors, to put the processor into free-run mode (just counting addresses, executing NOP's). Room is made for binary I/O, PSU, later: QWERTY keyboard, floppy drive, hard drive.
Z80 microcomputer (SYSTEM B)
This is the progress on my Z80 computer project! I've recently received the needed components, and has begun construction.
The idea is, to make a eurocard (that's a PCB standard size) and backplane based microcomputer, which can be operated as simply as possible, but that also will allow for infinite expansions.
Phase 1 consists on little more than a buffered CPU card with clock, and a bus display card, showing the logic level of the address and data bus as well as some control bus signals.
The "enclosure" is made of wood, to give that 70's homebrew feel, and the plan is not to use any component that didn't exist in the early to mid-80's.
Above can be seen the first card to be plugged into the backplane. The connectors are DIN 41617 connectors, because i like how the pins match up with regular stripboard. The card pcb's is IC-island types, FR4 material. The 4 20-pin packages are simply buffers for various busses.
I use a mix of prototyping techniques, here it's wire-wrap, though i use standard 0.1-inch header pins as wrap posts. This has two major advantages, 1) The card becomes very low-profile, with the height being about 1,5 cm instead of the almost 4 with ordinary wrap sockets. 2) each socket costs a fraction of a wire-wrap one. The connection might not be as good, though. I've yet to experience problems with that.
Abonner på:
Kommentarer (Atom)




