Want to read Slashdot from your mobile device? Point it at m.slashdot.org and keep reading!

 



Forgot your password?
typodupeerror
×
Education Hardware

Microcomputers for Homebrew Projects? 68

tengwar asks: "Way back when I was at university, I did a course on microcomputers which went into enough detail to design, build and program a Z80-based system - more or less state of the art at the time. Now that my lecture notes are firmly embedded in the Carboniferous layer, I'd like to have a go at doing this with a more modern chip, and I wondered what's available. I'm not brilliant at electronics, and I liked the way the Z80 peripheral chips integrated easily with the CPU. Obviously I'm not looking to just slot together the latest PC motherboard with the latest Pentium, but I'd need to go for something where the board design won't get too complicated, which probably rules out processors with full 32-bit external interfaces on space grounds. I'm not really concerned about performance, but it would be nice to be able to port a JRE to it rather than working entirely in assembler. Any thoughts on suitable starting points?"
This discussion has been archived. No new comments can be posted.

Microcomputers for Homebrew Projects?

Comments Filter:
  • Atmel AVR (Score:4, Informative)

    by glassesmonkey ( 684291 ) * on Saturday August 30, 2003 @05:46PM (#6835071) Homepage Journal
    I'm not sure if anything short of Pentium/Athlon would be state of the art enough, but I'd recommend the Atmel AVR. Firstly, there are lots of demo/examples with it and existing software archives exist.
    This processor is used in some smart-sensor [xbow.com] applications where you have distributed sensors.
    Here's a 1998 EDN mag review [reed-electronics.com] and some simm circuit boards [simmstick.com] which make project computers.
    • They're powerful (considering their cost, $3 to $12 each), and very easy to program.

      http://www.avrfreaks.net/ is an excellent AVR resource.

      In addition, you can program AVRs in C rather than assembler. There is a GCC version that targets the AVR platform, although my preference has been for Codevision AVR compiler/IDE/library set- It's $150 for a full version, but worth every penny (Mainly for the library set it comes with. No need to write your own I2C, One-Wire, or LCD interface routines, as CV-AVR has
  • Not that easy (Score:4, Informative)

    by keesh ( 202812 ) * on Saturday August 30, 2003 @05:47PM (#6835076) Homepage
    One of the reasons you won't get modern CPUs to work on hand-made boards is the length of connections. With the z80, you can trim wires by hand and it'll still work quite happily; with faster CPUs, though, you need to be far more precise with the length of the wires / tracks connecting the CPU to memory and the like. At speeds of over a few MHz, even a mm difference is more than enough to screw things up...
  • microcontrollers (Score:5, Informative)

    by wotevah ( 620758 ) on Saturday August 30, 2003 @05:48PM (#6835084) Journal
    If you forget about java and a VGA display, you can do a lot of fun things in C with a single microcontroller chip. Microchip [microchip.com] makes an entire range of fairly cheap, very low-power microcontrollers, flash- or one-time programmable. There are also other companies that make enhanced versions of the venerable 80C51 such as the Philips 80C552 with integrated A/D converters and PWM outputs although depending on your soldering/wrapping abilities you might not want to use them as they have quite a few pins!

    Microcontrollers are extremely small, low-powered devices containing a CPU, some code/data memory peripheral interfaces. You might have seen them at work in your preferred game station mod chip...

    I think Motorola, AMD and Intel also have a line of powerful 68xxx- and x86-, respectively, -based microcontrollers that might be closer to the capabilities of a PC processor.

    There are also some chips that you can program in Basic (ugh) via a small interpreter in their boot code. It really depends on what you are planning to do.

    • Re:microcontrollers (Score:2, Interesting)

      by Josh Booth ( 588074 )
      Those BASIC Stamps you are talking about are really Microchip PIC's (Periferal Interface Controllers) with an interperator program. You can buy your own, though, and assembly code them or download the C compiler for it and use a subset of C.
    • Re:microcontrollers (Score:2, Interesting)

      by foureyes ( 615295 )
      If you don't feel like spending too much time mucking around with assembly or C, or dropping 50 dollars on a programmer, or putting together all the supporting circuitry around the chip (the clock, adc, etc.), then you should probably try the BX-24. It's programmed in a Basic environment (which I guess could be either good or bad depending on who's using it), so it's dead easy to get something up and running really quickly.
    • Re:microcontrollers (Score:3, Informative)

      by Judg3 ( 88435 )
      Another good thing about Microchip.com: http://sample.microchip.com/ [microchip.com].
      Pick up to 5 items and have em FedEx'ed to your home. It's a great way to check out a new chip you where wondering about, and not spend the money on it. Granted, it's only 5-25$ per piece, but that's 5-25$ you might waste if you get a new chip to play with and end up toasting it.
  • Well (Score:3, Informative)

    by GigsVT ( 208848 ) on Saturday August 30, 2003 @05:51PM (#6835098) Journal
    PIC, or AVR generally is where you should start. There's really no way around working in either Assembly or C if you want to do anything serious with it.

    To go to a more powerful CPU gets you into all the stuff you don't want to get into, like critical and complex board layouts.

    There's BASIC compilers, but you aren't going to get very far before you run into some serious limitations if you want to do anything complex.

    Good luck on the JRE thing, something like that is way too slow and bloated to run on a hobbiest CPU. I think sun made a chip that executed bytecode, but I don't think they make them anymore.
    • Re:Well (Score:3, Insightful)

      by FFFish ( 7567 )
      I suggest working in Forth. It's not overly difficult to write the innermost Forth kernel, no matter which processor you choose; many are only a few hundred bytes long. From there, you begin using Forth to write more Forth, extending the language as needed for your particular application.

      One bonus to this is that not only have your designed and built your own computer from CPU up, but also your own OS/Application from NOP up.
      • I suggest working in Forth.

        Certainly a good idea - it's just I have this allergic reaction to the aesthetics of Forth which I suppose I'll have to overcome.

    • There are micro JREs running on small hardware (most modern mobile phones use it). As others seems to be leaning towards ARM, I'm pretty sure one of them could run Java at some kind of acceptable speed.
    • Good luck on the JRE thing, something like that is way too slow and bloated to run on a hobbiest CPU.

      That's not true. Check out The TINI [ibutton.com].
      You can also program it in 8051 assembly, AND with the 1-wire interface you can hook a buttload of different sensors and things to it.

  • ARMBoards (Score:5, Interesting)

    by brejc8 ( 223089 ) * on Saturday August 30, 2003 @05:57PM (#6835115) Homepage Journal
    We have made a few ARM Boards [man.ac.uk] to teach undergraduate students. They work with ARM Angel or with our own debugger KMD [freshmeat.net]. You can write code in asm or C or any even gcc front end (inc java).
    The best feature for me is the huge FPGA's to play around with [man.ac.uk]. Its quite easy to pick up any electronic equipment and plug it into it. Lots of fun and great experience gaining stuff.
    The board total was around 100 GBP (inc board manufacture and mounting) and I think if you ask nicely the designs will be available.

    Alternatively you could use something like a 6809 or an 8051 but then writing code for them is a pain. The best idea if you use someting old is to emulate a better processor. You can then run your favorite ARM/MIPS/x86 code on an emulation and forget the real system.
  • Try Arm on for size (Score:5, Interesting)

    by madmaxx ( 32372 ) <mx@warpedvisions . o rg> on Saturday August 30, 2003 @06:14PM (#6835182) Homepage
    You might try an Arm [arm.com] processor, many of which have great built-in features (like NIC, daq, memory management). You can get demo [nuhorizons.com] boards [unicoi.com], and run linux [linux.org.uk] + related gnu tools on them. ARM-based systems make great embedded/distributed systems (aka 'the future'), and are a useful to learn for the old-resume.
  • A few suggestions (Score:2, Interesting)

    by EdMack ( 626543 )
    Firstly, these are good, and cheap: http://www.oopic.com/
    They can be programmed with java, c and much more, yet are basic. They are made to work well with servos and such, and are very versitile (read up on vitural circuit)

    For a more expensive option, the famous mini-itx boards are great, and robot sized heh http://www.mini-itx.com/
    Starting at about the same price as a microcontroller (well, some)!! Java is here too :)

    I suppose I'm more looking into cpus for robots, so maybe this is not ideal.
  • by psyconaut ( 228947 ) on Saturday August 30, 2003 @06:20PM (#6835214)
    I've been using Jave modules for a while...both from DalSemi/MAXIM (the "TINI", http://www.ibutton.com) and Imsys (the "SNAP", http://www.imsys.se).

    They provide a JRE environment (JDK1.1.3 in the case of TINI, J2ME CLDC 1.0 in the case of SNAP) and allow me not to worry about processor and memory design etc.

    Right now, my SNAP module lives in a custom extuded aluminum enclosure I designed, and has a MMC interfaced for it (an extra 16Mbytes of removable storage), and a bunch of other things like temperature/humidity sensors, LEDs, an LCD, and dry contact sensors.

    One reason I like both these modules is that they support I2C, SPI and 1-wire for expansion....meaning that you don't have to necessarily hang stuff off the CPU's data bus.

    Good luck.

    -psy
    • Yes, for actually getting stuff done I like the TINI - nice to work with and very cheap. I've not tried the SNAP but I've heard good things about it. However they're basically ready-built whereas in this case I'm interested in building from the CPU up - I suppose mainly to see if it can still be done.
      • I've done PIC stuff aside from the pre-built modules....

        Have you considered an ARM core? They're quite easy to work with....from what I know/am told.

        -psy
      • Edumucation (Score:3, Interesting)

        by poptones ( 653660 )
        Is this for real education or just a toy? If the goal is education then thinking in terms of wire and solder is antiquated - like teaching vacuum tube design to freshmen just because it's easier than understanding holes and heatsinks.

        Better I would think to start with an FPGA. I did a lab like this when I was in school - not that it was being taught in the course, just that I was bored with the labs so decided to make my lab reports more interesting. Take an adder (in my case it was an actual 74181) and sh

    • I took a class at brandeis in the physics dept and we did PIC based stuff. We used an 8 bit Pic with i think 13 IO lines. It was a very good class and I learned a hell of a lot. We used PIC basic and assembler. (It was a physics class not computer science).

      There was quite a bit of equipment we ended up needing, including the programer (to put the code on the chips) a breadboard (actually several) and a very good osilascope. If you have access to this kind of stuff it could be worth it.

      One problem DIP prof
      • I do surface mount stuff at home all the time...it's not nearly as hard as most people make it out to be! It's quite easy to solder a TSOC, SOIC8 or SOIC16 component onto a breadboard adapter (I make my own).

        And just about everything Microchip (the PIC folks) make is available in DIP ;-)

        -psy
  • Where to start (Score:5, Informative)

    by jcwren ( 166164 ) on Saturday August 30, 2003 @06:49PM (#6835330) Homepage

    If you *really* want a JRE (which is generally not synonymous with performance, in the microcontroller world), check out the TINI from Dallas Semiconductor, here [ibutton.com].

    If you want to get into heavier duty gear (and available only in surface mount), you can look at things like the Patriot from PTSC, here [ptsc.com]. There are also several others that I've seen, but can't recall the name of. A little Googling [google.com] should find those.

  • Atmel make 8 bit micros that are pretty easy to interface with. You would probably be out of luck porting a JRE, but there is a C compiler for it.

    JStamp make native java hardware. Never used them though.

  • Motorola Dragonball? (Score:4, Informative)

    by innosent ( 618233 ) <jmdority.gmail@com> on Saturday August 30, 2003 @07:32PM (#6835487)
    If you want a processor, and not just a microcontroller, but still want it fairly simple, you might want to check Motorola's Dragonball chips. It sounds like you want something with a low pin count, and simple ISA, so that'd be my first suggestion, followed very closely by ARM.

    If you want a microcontroller, then maybe the 68HCxx series, or a RISC-ish PIC. The 68HCxx series is probably the most popular there, and you can easily find code and design samples for them.
    • HC12 (Score:4, Informative)

      by epine ( 68316 ) on Saturday August 30, 2003 @07:54PM (#6835581)

      I had to get back into microcontrollers, after a long absence (since the days when the 6809 was state of the art).

      I decided to go with the Motorola HC12. Unlike the HC11, it runs compiled C code with reasonable efficiency (gcc supported), it's highly integrated, and you have a simple execution model (not very many registers, etc.) when debugging by hand. It's reasonably capable, and almost trivial to design your own project board (clock frequencies within reason, few external components required, every kind of I/O pin conceivable).

      The more powerful versions have huge amounts of internal FLASH (256K), but not quite as much internal memory as I would like (8K is typical of recent versions).

      There are cheap modules available from Technological Arts in Toronto. They don't seem to be very active this year with new designs, but they continue to supply their product line to local colleges last I checked.

      Anything more complex than an HC12 I think I would want some kind of kernel OS. The next step up the food chain, in our evaluation, was an Atmel chip.
  • i think the z80 still can be used. modern doesn't mean too much on that scale. for more complex things Zilog [zilog.com] makes a pretty big line of various processors for different uses.
  • mmm. beer (Score:3, Funny)

    by FrenZon ( 65408 ) * on Saturday August 30, 2003 @09:08PM (#6835846) Homepage
    Nuts, I thought the title was Home Computers for Microbrew Projects. So I am understandably disappointed with the non-beer focus of these comments.

  • You know, the Z80 is still in production [zilog.com], and your experience helps explain why. It's a useful, accessible CPU. I mean, why are you doing this? Fun, self-edification? If so, the Z80 suits your purpose as well as it every did.
  • If you want to go really hardcore, check out homebrewcpu.com [homebrewcpu.com]. That guy basically made a processor out of TTL components. I was actually searching google about this very same thing the other day and came across that site(although not much else other than old homebrew computer clubs).
    • This looks like fun, but a bit beyond me. I've wondered about building an OISC [wikipedia.org] - should be the simplest CPU to build, but a real bear to program (do bears program in the woods?). But using 74 series components? Doesn't he know Real Men knaw individual transistors out of solid silicon?
  • You might want to check out JK microsystems. [jkmicro.com]

    For $69 you can get a 33mhz 80186 board with 512k of flash and ram, a flash file system, and a full Borland development ide. You get 44 digital I/O lines plus the raw processor bus and a bunch of integrated peripherals.

  • MSP430 series from Texas Instruments are quite good (and with ultra-low power consumption). They also have GNU toolchain available.
  • Why not directly jump at designing a Java processor? SUN's PicoJava architecure is AFAIK publicly available, at least for educational use.

    And as you are at it, you could as well design this as a PCI board to finally speed up Java on the desktop :o)
  • Personally, I prefer Atmel AVR devices these days. atmel.com and www.avrfreaks.com will give you all the info you need. Z-80 is still around in different guises. Zilog has a few single board computers that can run C and other languages and they're pretty inexpensive for what you get. Can even get them with webserver code! If you want to build another Z80 machine, get back to me. I have tubes of Z80s, Z80-CTC, Z80-PIO (I think) 32k EPROMS and 32k SRAMS sitting in my basement that I will probably never use.
  • Rabbit Semiconductor makes a Z80 compatible which has all sorts of interesting hardware on-board, like a PWM generator and two quadrature encoders.
    -russ
  • Remember that for embedded stuff, you want low power consumption. And for that, you'll have a relatively slow (by modern desktop PC standards) CPU. A JRE will use a stupid amount of CPU horsepower just to run, so your actual embedded system will run like a bag of shit. Can you imagine if the ABS controller in your car used Java? <shudder>

    Learn C. It's pretty similar to Java, but is far more suitable for writing embedded controller software. Remember that you are going to be controlling things,
    • Remember that for embedded stuff, you want low power consumption.

      I didn't mention imbedded stuff. I'm only interested in building a computer, not using it for something practical - there's plenty of off-the shelf stuff for that.

      Learn C. It's pretty similar to Java, but is far more suitable for writing embedded controller software. Remember that you are going to be controlling things, not drawing widgets on a screen, so an OO language is not really necessary (or even desirable). Instead, you will be re

    • A JRE will use a stupid amount of CPU horsepower just to run, so your actual embedded system will run like a bag of shit.

      It's unbelievable that someone who knows something of embedded systems would post this kind of vitriol without posting benchmarks or, at the very least, performing a google search [google.com] first. It's also disturbing that the myth about Java's slowness is still stuck in people's heads. Java's bytecode certainly does not execute as fast as native code, but making a blanket statement about the p

  • www.arcom.com they do a range and some of them can run a jre and linux.
  • What ya wanna do is subscribe to Circuit Cellar [circuitcellar.com] the magazine that is today what BYTE magazine was back in the z80 days. Full of articles on using modern, small processors to do "stuff". They also run some great Design Contests supported by various manufacturers that get you a development board and software (and generally extra chips!) for free.
    These days, at the low end (less than 100 MHz), there is seldom a need to wire a processor up to much of any peripherals. For example, the motorola Coldfire [motorola.com] proc
  • actually pretty easy (Score:4, Informative)

    by dutky ( 20510 ) on Monday September 01, 2003 @02:21PM (#6845383) Homepage Journal
    Check out my journal [slashdot.org] for some discussion of exactly how to do such a thing. The first bit of advice is that you should consider a microcontroller as the heart of the system. There are lots of good candidates out there: PPC, ARM, and MIPS devices are common. You might be able to find some x86 based devices as well.

    Many of the current MCUs are ball grid array (BGA) devices, which make them pretty hard to work with if you're not a professional, but a few can be had in PLCC or QFP packages, which means you can get an adapter board or socket.

    You can also buy preassembled demo/development boards (this is the route I'm taking) and wire-up anything the board doesn't include by hand. Most of the MCUs on the market will have 32-bit memory busses (though they may not support more that 25 or 26 address lines), so you can attach just about anything you want to them.

    This is exactly the kind of thing that Steve Ciarcia (of Ciarcia's Circuit Cellar [circuitcellar.com]) used to do: building personal computers from microcontrollers. Most of his designs used Z80 based devices, which was fine back in the mid- to late-eighties. Now, however, you can do a fair bit better.

    As for speed, I don't know exactly what you're looking for, but the ARM devices can be had in speeds from 50MHz to 400MHz, and the same is true of the PPC and MIPS devices. That may not seem like much, compared to a 2GHz Pentium, but it's really quite nice.

    Some good resources: Digi-Key [digikey.com] is a reasonable source for all sorts of parts, Atmel [atmel.com] makes some nice MCUs, programmable logic, and Flash RAM, Cirrus Logic [cirrus.com] makes some ARM MCUs and networking chips (amoung other things), Sharp [sharpsma.com], Samsung [samsung.com], Motorola [motorola.com], and AMD [amd.com] all make nice MCUs, Cogent Computers [cogcomp.com] builds some nice development boards, and EarthLCD [earthlcd.com] has good prices on LCDs and has an ARM based board in the works.

    • There are lots of StrongArm style chips that would make a good project. DragonBall and Coldfire chips are also available. I would dump JVM as go with c or c++ if you do not want asm. And yes many of them you can run Linux on.
  • Forgot one thing... You simply don't have to program any of these chips in assembler any more, free software will get you where you need to be. Most, if not all, are supported by GCC, and most (if not all) have a port of the remote side of GDB available. Write in C++, debug in GDB over a serial link, and you're doing pretty good. You can also get free operating system software for them, ranging from simple multi-tasking kernels (uCos, eCos, etc) to full-blown desktop style OSs with filesystems (e.g.e uC
  • A company called Ampro has these little 486 boards complete with Ethernet, PS/2, IDE and VGA connections and they are affordable.
  • Depending on what you want to do, a DSP may be the answer.

    TI makes a few good ones. Advantages over a MicroController? How about a decent Math package (fixed point or floating point), built in programmers, and a large array of I/O options? The DSPs I've been playing with have 3 General I/O registers, any pin of the 24 available to the GIO can be configured to be input or output.

    Add on integrated ADCs and DACs, and a decent clock speed, and you've got a nice system.

    Did I mention that you can find older
  • In my experience embedding processors in very tiny MEMS sensor packages (smaller than a postage stamp) the Microchip Inc. PIC processors are an excellent embedded processor with many low cost programming tools. The PIC16f876 is particularly neat with a flash reprogrammable ROM and in circuit programability. But the 8 pin designs pack quite a wallop as well.

    The Javelin is java version of the basic stamp for the more hardware adverse, For low performance work the Basic stamp is excellent.

    Finally the uClinux
  • Parallax [parallax.com] has "stamps" that run either BASIC or JAVA programs. They've got a variety of different chips with different capabilities. Better yet, there's plenty of documentation, plans, etc., out there for them.

    Sure they don't have the power of some of the beefier solutions mentioned, but they're much easier to get into.

I tell them to turn to the study of mathematics, for it is only there that they might escape the lusts of the flesh. -- Thomas Mann, "The Magic Mountain"

Working...