|  |  | |||
| TAMS / Java / Hades / applets: contents | previous | next | ||||
| Hades Applets contents visual index  introduction  std_logic_1164  gatelevel circuits  delay models  flipflops  adders and arithm...  counters  LFSR and selftest  memories  programmable logic  state-machine editor  misc. demos  I/O and displays  DCF-77 clock  relays (switch-le...  CMOS circuits (sw...  RTLIB logic  RTLIB registers  Prima processor  D*CORE  MicroJava  Pic16 cosimulation  Mips R3000 cosimu...  Intel MCS4 (i4004)    MCS4 Overview    MCS4 binary ...    MCS4 BCD add...    MCS4 binary ...    MCS4 BCD sub...    MCS4 RAM add...    MCS4 RAM sub...    MCS4 increment    MCS4 increme...    MCS4 calculator    i4003 shift-...    MCS4 I/O ports    MCS4 Counter  image processing ...  [Sch04] Codeumsetzer  [Sch04] Addierer  [Sch04] Flipflops  [Sch04] Schaltwerke  [Sch04] RALU, Min...  [Fer05] State-Mac...  [Fer05] PIC16F84/...  [Fer05] Miscellan...  [Fer05] Femtojava  FreeTTS | Intel MCS4 (i4004) BCD subtraction
Circuit Description
A realization of BCD subtraction on the i4004 microprocessor
based on this assembly source: bcd_sub.asm. 
 
; bcd_sub.asm
; subtract two 4bit numbers on the Intel 4004
; bcd-wise
    FIM R0R1, 0x42 ; initialize R0=2 & R1=4
    FIM R2R3, 0    ; clear result pair
    LD R0          ; load R0 into accumulator
    SUB R1         ; subtract second number
    XCH R1         ; and store in R1
    JCN C, end     ; carry not set when result<0
    LD R1          ; load result into accumulator
    CMA            ; build complement of accu
    CLC            ; clear carry
    IAC            ; increment accu (=> 2-complement)
    XCH R1         ; right result back to R1
    STC            ; set carry to show borrow
done:
    JUN done       ; end 
This short program demonstrates a single digit BCD subtraction on the i4004. As the MCS4 system was originally designed for a printing desktop calculator, binary-coded-decimal arithmetic was one of the main application areas of the MCS4. To watch the program execution, open the user-interface of the i4004 processor and the i4001 ROM chip memory editor. (On Windows, you may have to resize and move the windows a little, so that all windows remain readable during the simulation.) 
Again, you may want to single-step through the program
with the technique explained in the MCS4 overview,
because the program is so short.
Type the value  See also: 
 
 | |||
| Print version | Run this demo in the Hades editor (via Java WebStart) | ||||
| Usage | FAQ | About | License | Feedback | Tutorial (PDF) | Referenzkarte (PDF, in German) | ||||
| Impressum | http://tams.informatik.uni-hamburg.de/applets/hades/webdemos/80-mcs4/sub/bcd_sub.html |