reworkings
authorBernard Blackham <[email protected]>
Wed, 6 Aug 2003 03:08:13 +0000 (03:08 +0000)
committerBernard Blackham <[email protected]>
Wed, 6 Aug 2003 03:08:13 +0000 (03:08 +0000)
ROM2/Makefile
ROM2/display.c
ROM2/helpers.c
ROM2/main.c
ROM2/ports.h [new file with mode: 0644]
ROM2/vend.h

index 7995df9..6c77f24 100644 (file)
@@ -6,12 +6,17 @@ OBJS = \
 INCLUDES = vend.h
 
 
-CFLAGS = -O2 -Wall -m68hc11 -mshort -Wall -Wmissing-prototypes -Os -g0 \
+CFLAGS = -O2 -Wall -m68hc11 -mshort -Wall -Os -g0 \
        -msoft-reg-count=0 -ffixed-z
 
 LDFLAGS = -m68hc11 -mshort -Wl,-m,m68hc11elfb \
          -nostartfiles \
-         -Wl,-defsym,_io_ports=0x1000
+         -Wl,-defsym,_io_ports=0x1000 \
+         -Wl,-defsym,_switch_input=0x1800 \
+         -Wl,-defsym,_misc_input=0x2000 \
+         -Wl,-defsym,_home_sensors=0x2800 \
+         -Wl,-defsym,_changer_output=0x3000 \
+         -Wl,-defsym,_misc_output=0x3800
 
 OBJCOPY_FLAGS=--only-section=.text \
               --only-section=.rodata \
@@ -36,6 +41,16 @@ rom2.elf: $(OBJS) memory.x
 clean:
        rm -f $(OBJS) *.elf *.s19 *.b *.a
 
+#
+# Some useful rules
+#
+dump:  rom2.elf
+       $(OBJDUMP) -d $<
+
+size:   rom2.s19
+       $(SIZE) $<
+
+
 #
 # Implicit rules
 #
index ee3e94b..3ab045b 100644 (file)
@@ -4,52 +4,78 @@
  * Use set_msg(char*) to write a new message to the screen, replacing the previous
  * one. The message can be at most 1023 characters long. Use set_wrap_mode with
  * one of the WRAP_* options in vend.h to set the scrolling behaviour. If the
- * message is less than 10 characters, it is centered and is not scrolled.
- * Otherwise, the message will scroll.
+ * message is less than 10 characters, it is not scrolled.  Otherwise, the
+ * message will scroll.
  *
  */
 
-
 #include "vend.h"
 
 char display_buffer[10];    /* what each byte on the display reads          */
 char current_message[1024]; /* message that is scrolled or switched between */
 u8   wrap_mode;             /* whether to scroll or alternate between msgs  */
 
+/* private prototypes */
+void display_send_byte(char c);
+void display_reset();
+void display_update();
+
+
 void set_msg(char* newmsg) {
        char* dest = current_message;
+       /* equivalent of a string copy */
        /* while (dest++ = newmsg++); */
        while (newmsg) {
                dest = newmsg;
                dest++;
                newmsg++;
        }
+       display_update();
 }
 
-void __inline__ set_wrap_mode(u8 new_wrap_mode) {
+inline void set_wrap_mode(u8 new_wrap_mode) {
        /* in theory it should be inlined anyway? */
        wrap_mode = new_wrap_mode;
 }
 
-void display_send_byte(u8 b) {
-       bset_3800(A3800_DISPLAY_WRITE);
+void display_send_byte(char c) {
+       *_misc_output |= A3800_DISPLAY_WRITE;  /* enable the display clock */
+
+       _io_ports[M6811_SPDR] = c;            /* load SPI with byte */
+       while(!(_io_ports[M6811_SPDR]&0x80)); /* wait for completion */
 }
 
 #define DISPLAY_DELAY  100 /* ms to delay between ops - could be tweaked */
 void display_reset() {
-       /* lower the reset line for 100ms */
-       bclr(PORTA, PORTA_DISP_RESET);
+       /* lower the reset line for a while */
+       _io_ports[M6811_PORTA] &= ~PORTA_DISP_RESET;
        delay(DISPLAY_DELAY);
-       bset(PORTA, PORTA_DISP_RESET);
+       _io_ports[M6811_PORTA] |= PORTA_DISP_RESET;
 
-       /* enable the SPI */
-       bset(SPCR, SPCR_SPE);
+       _io_ports[M6811_SPCR] |= M6811_SPE;       /* enable the SPI */
        delay(DISPLAY_DELAY);
 
-       /* tell the controller there are 10 digits */
+       display_send_byte(0xCA);    /* tell the controller there are 10 digits */
+       display_send_byte(0xE0);    /* set duty cycle to 100%                  */
+
+       _io_ports[M6811_SPCR] &= ~M6811_SPE;       /* disable the SPI again */
+}
+
+void display_update() {
+       int i;
+       display_reset();
        
+       for (i=0; i < 10; i++) {
+               /* FIXME: we may need to fiddle with the character codes sent to the 
+                * controller. It doesn't seem like we have to, but datasheets for
+                * the "pin-for-pin" compatible MSC1937 from OKI suggest a different
+                * character set
+                */
+               display_send_byte(i[display_buffer]&0x7f);
+       }
 }
 
-void display_refresh() {
+void display_init() {
        display_reset();
 }
+
index 283ca30..71c1007 100644 (file)
@@ -1,45 +1,18 @@
 #include "vend.h"
 
-/* some IO addresses require buffering, so we create some generic buffering
- * functions here
- */
-
-/* create port-specific #defines: */
-#define buffered_port(p) \
-       u8   addr_##p##_buffer = 0; \
-       \
-       void __inline__ outb_##p(u8 b) { \
-               addr_##p##_buffer = b; \
-               outb(p, b); \
-       } \
-       \
-       void __inline__ bset_##p(u8 mask) { \
-               bset((addr_t)&addr_##p##_buffer, mask); \
-               outb(p, addr_##p##_buffer); \
-       } \
-       \
-       void __inline__ bclr_##p(u8 mask) { \
-               bclr((addr_t)&addr_##p##_buffer, mask); \
-               outb(p, addr_##p##_buffer); \
-       } 
-
-void __inline__ outb(addr_t addr, u8 byte) {
-       /* FIXME hmmm */
-       /* asm? */
-}
-
-void __inline__ bset(addr_t addr, u8 mask) {
-       /* FIXME again. asm? */
-}
-
-void __inline__ bclr(addr_t addr, u8 mask) {
-       /* FIXME again. asm? */
-}
-
 void delay(u16 ms) {
        /* FIXME fill me in */
 }
 
-/* ports declared here must be defined with buffered_port_h() in vend.h too */
-buffered_port(3800);
+#define buffered_addr(a) \
+       u8 a; \
+       inline void set_##a(u8 b) { a = *_##a = b; } \
+       inline void bset_##a(u8 m) { a |= m; *_##a = a; } \
+       inline void bclr_##a(u8 m) { a &= ~m ; *_##a = a; }
+
+buffered_addr(switch_input)
+buffered_addr(misc_input)
+buffered_addr(home_sensors)
+buffered_addr(changer_output)
+buffered_addr(misc_output)
 
index 3331548..9d59f60 100644 (file)
@@ -1,5 +1,24 @@
 #include "vend.h"
 
+int main() {
+       /* do stuff */
+       set_msg("UNIVERSITY");
+       delay(1000);
+       set_msg(" COMPUTER ");
+       delay(1000);
+       set_msg("   CLUB   ");
+       delay(1000);
+
+       while(1) {
+       }
+}
+
 void _start() {
+       /* Initialize Stuff.  Particularly some memory locations that can only be
+        * written in the first 64 clock cycles upon reset.
+        */
+       display_init();
+       set_bus_expanded();
+       main();
 }
 
diff --git a/ROM2/ports.h b/ROM2/ports.h
new file mode 100644 (file)
index 0000000..fe5236f
--- /dev/null
@@ -0,0 +1,504 @@
+/* ports.h
+ Copyright (C) 1999 Free Software Foundation, Inc.
+ (C) 2000 Stephane Carrez ([email protected])
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
+*/
+
+#ifndef _M68HC11_PORTS_H 
+#define  _M68HC11_PORTS_H 
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/* Flags for the definition of the 68HC11 CCR.  */
+#define M6811_S_BIT     0x80    /* Stop disable */
+#define M6811_X_BIT     0x40    /* X-interrupt mask */
+#define M6811_H_BIT     0x20    /* Half carry flag */
+#define M6811_I_BIT     0x10    /* I-interrupt mask */
+#define M6811_N_BIT     0x08    /* Negative */
+#define M6811_Z_BIT     0x04    /* Zero */
+#define M6811_V_BIT     0x02    /* Overflow */
+#define M6811_C_BIT     0x01    /* Carry */
+
+/* 68HC11 register address offsets (range 0..0x3F or 0..64).
+    The absolute address of the I/O register depends on the setting
+    of the M6811_INIT register.  At init time, the I/O registers are
+    mapped at 0x1000.  Address of registers is then:
+    0x1000 + M6811_xxx
+*/
+
+#define M6811_PORTA     0x00    /* Port A register */
+#define M6811_DDRA      0x01    /* Data direction register for port A */
+#define M6811_PORTG     0x02    /* Port G register */
+#define M6811_DDRG      0x03    /* Data direction register for port G */
+#define M6811_PORTB     0x04    /* Port B register */
+#define M6811_PORTF     0x05    /* Port F register */
+#define M6811_PORTC     0x06    /* Port C register */
+#define M6811_DDRC      0x07    /* Data direction register for port C */
+#define M6811_PORTD     0x08    /* Port D register */
+#define M6811_DDRD      0x09    /* Data direction register for port D */
+#define M6811_PORTE     0x0A    /* Port E input register */
+#define M6811_CFORC     0x0B    /* Compare Force Register */
+#define M6811_OC1M      0x0C    /* OC1 Action Mask register */
+#define M6811_OC1D      0x0D    /* OC1 Action Data register */
+#define M6811_TCTN      0x0E    /* Timer Counter Register */
+#define M6811_TCTN_H    0x0E    /* "     "       " High part */
+#define M6811_TCTN_L    0x0F    /* "     "       " Low part */
+#define M6811_TIC1      0x10    /* Input capture 1 register */
+#define M6811_TIC1_H    0x10    /* "     "       " High part */
+#define M6811_TIC1_L    0x11    /* "     "       " Low part */
+#define M6811_TIC2      0x12    /* Input capture 2 register */
+#define M6811_TIC2_H    0x12    /* "     "       " High part */
+#define M6811_TIC2_L    0x13    /* "     "       " Low part */
+#define M6811_TIC3      0x14    /* Input capture 3 register */
+#define M6811_TIC3_H    0x14    /* "     "       " High part */
+#define M6811_TIC3_L    0x15    /* "     "       " Low part */
+#define M6811_TOC1      0x16    /* Output Compare 1 register */
+#define M6811_TOC1_H    0x16    /* "     "       " High part */
+#define M6811_TOC1_L    0x17    /* "     "       " Low part */
+#define M6811_TOC2      0x18    /* Output Compare 2 register */
+#define M6811_TOC2_H    0x18    /* "     "       " High part */
+#define M6811_TOC2_L    0x19    /* "     "       " Low part */
+#define M6811_TOC3      0x1A    /* Output Compare 3 register */
+#define M6811_TOC3_H    0x1A    /* "     "       " High part */
+#define M6811_TOC3_L    0x1B    /* "     "       " Low part */
+#define M6811_TOC4      0x1C    /* Output Compare 4 register */
+#define M6811_TOC4_H    0x1C    /* "     "       " High part */
+#define M6811_TOC4_L    0x1D    /* "     "       " Low part */
+#define M6811_TOC5      0x1E    /* Output Compare 5 register */
+#define M6811_TOC5_H    0x1E    /* "     "       " High part */
+#define M6811_TOC5_L    0x1F    /* "     "       " Low part */
+#define M6811_TCTL1     0x20    /* Timer Control register 1 */
+#define M6811_TCTL2     0x21    /* Timer Control register 2 */
+#define M6811_TMSK1     0x22    /* Timer Interrupt Mask Register 1 */
+#define M6811_TFLG1     0x23    /* Timer Interrupt Flag Register 1 */
+#define M6811_TMSK2     0x24    /* Timer Interrupt Mask Register 2 */
+#define M6811_TFLG2     0x25    /* Timer Interrupt Flag Register 2 */
+#define M6811_PACTL     0x26    /* Pulse Accumulator Control Register */
+#define M6811_PACNT     0x27    /* Pulse Accumulator Count Register */
+#define M6811_SPCR      0x28    /* SPI Control register */
+#define M6811_SPSR      0x29    /* SPI Status register */
+#define M6811_SPDR      0x2A    /* SPI Data register */
+#define M6811_BAUD      0x2B    /* SCI Baud register */
+#define M6811_SCCR1     0x2C    /* SCI Control register 1 */
+#define M6811_SCCR2     0x2D    /* SCI Control register 2 */
+#define M6811_SCSR      0x2E    /* SCI Status register */
+#define M6811_SCDR      0x2F    /* SCI Data (Read => RDR, Write => TDR) */
+#define M6811_ADCTL     0x30    /* A/D Control register */
+#define M6811_ADR1      0x31    /* A/D, Analog Result register 1 */
+#define M6811_ADR2      0x32    /* A/D, Analog Result register 2 */
+#define M6811_ADR3      0x33    /* A/D, Analog Result register 3 */
+#define M6811_ADR4      0x34    /* A/D, Analog Result register 4 */
+#define M6811__RES35    0x35
+#define M6811__RES36    0x36
+#define M6811__RES37    0x37
+#define M6811__RES38    0x38
+#define M6811_OPTION    0x39    /* System Configuration Options */
+#define M6811_COPRST    0x3A    /* Arm/Reset COP Timer Circuitry */
+#define M6811_PPROG     0x3B    /* EEPROM Programming Control Register */
+#define M6811_HPRIO     0x3C    /* Highest priority I-Bit int and misc */
+#define M6811_INIT      0x3D    /* Ram and I/O mapping register */
+#define M6811_TEST1     0x3E    /* Factory test control register */
+#define M6811_CONFIG    0x3F    /* COP, ROM and EEPROM enables */
+
+/* Flags of the CONFIG register (in EEPROM).  */
+#define M6811_NOSEC     0x08    /* Security mode disable */
+#define M6811_NOCOP     0x04    /* COP system disable */
+#define M6811_ROMON     0x02    /* Enable on-chip rom */
+#define M6811_EEON      0x01    /* Enable on-chip eeprom */
+
+/* Flags of the PPROG register.  */
+#define M6811_BYTE      0x10    /* Byte mode */
+#define M6811_ROW       0x08    /* Row mode */
+#define M6811_ERASE     0x04    /* Erase mode select (1 = erase, 0 = read) */
+#define M6811_EELAT     0x02    /* EEPROM Latch Control */
+#define M6811_EEPGM     0x01    /* EEPROM Programming Voltage Enable */
+
+/* Flags of the PIOC register.  */
+#define M6811_STAF      0x80    /* Strobe A Interrupt Status Flag */
+#define M6811_STAI      0x40    /* Strobe A Interrupt Enable Mask */
+#define M6811_CWOM      0x20    /* Port C Wire OR mode */
+#define M6811_HNDS      0x10    /* Handshake mode */
+#define M6811_OIN       0x08    /* Output or Input handshaking */
+#define M6811_PLS       0x04    /* Pulse/Interlocked Handshake Operation */
+#define M6811_EGA       0x02    /* Active Edge for Strobe A */
+#define M6811_INVB      0x01    /* Invert Strobe B */
+
+/* Flags of the SCCR1 register.  */
+#define M6811_R8        0x80    /* Receive Data bit 8 */
+#define M6811_T8        0x40    /* Transmit data bit 8 */
+#define M6811__SCCR1_5  0x20    /* Unused */
+#define M6811_M         0x10    /* SCI Character length */
+#define M6811_WAKE      0x08    /* Wake up method select (0=idle, 1=addr mark) */
+
+/* Flags of the SCCR2 register.  */
+#define M6811_TIE       0x80    /* Transmit Interrupt enable */
+#define M6811_TCIE      0x40    /* Transmit Complete Interrupt Enable */
+#define M6811_RIE       0x20    /* Receive Interrupt Enable */
+#define M6811_ILIE      0x10    /* Idle Line Interrupt Enable */
+#define M6811_TE        0x08    /* Transmit Enable */
+#define M6811_RE        0x04    /* Receive Enable */
+#define M6811_RWU       0x02    /* Receiver Wake Up */
+#define M6811_SBK       0x01    /* Send Break */
+
+/* Flags of the SCSR register.  */
+#define M6811_TDRE      0x80    /* Transmit Data Register Empty */
+#define M6811_TC        0x40    /* Transmit Complete */
+#define M6811_RDRF      0x20    /* Receive Data Register Full */
+#define M6811_IDLE      0x10    /* Idle Line Detect */
+#define M6811_OR        0x08    /* Overrun Error */
+#define M6811_NF        0x04    /* Noise Flag */
+#define M6811_FE        0x02    /* Framing Error */
+#define M6811__SCSR_0   0x01    /* Unused */
+
+/* Flags of the BAUD register.  */
+#define M6811_TCLR      0x80    /* Clear Baud Rate (TEST mode) */
+#define M6811__BAUD_6   0x40    /* Not used */
+#define M6811_SCP1      0x20    /* SCI Baud rate prescaler select */
+#define M6811_SCP0      0x10
+#define M6811_RCKB      0x08    /* Baud Rate Clock Check (TEST mode) */
+#define M6811_SCR2      0x04    /* SCI Baud rate select */
+#define M6811_SCR1      0x02
+#define M6811_SCR0      0x01
+
+#define M6811_BAUD_DIV_1        (0)
+#define M6811_BAUD_DIV_3        (M6811_SCP0)
+#define M6811_BAUD_DIV_4        (M6811_SCP1)
+#define M6811_BAUD_DIV_13       (M6811_SCP1|M6811_SCP0)
+
+/* Flags of the SPCR register.  */
+#define M6811_SPIE      0x80    /* Serial Peripheral Interrupt Enable */
+#define M6811_SPE       0x40    /* Serial Peripheral System Enable */
+#define M6811_DWOM      0x20    /* Port D Wire-OR mode option */
+#define M6811_MSTR      0x10    /* Master Mode Select */
+#define M6811_CPOL      0x08    /* Clock Polarity */
+#define M6811_CPHA      0x04    /* Clock Phase */
+#define M6811_SPR1      0x02    /* SPI Clock Rate Select */
+#define M6811_SPR0      0x01
+
+/* Flags of the SPSR register.  */
+#define M6811_SPIF      0x80    /* SPI Transfer Complete flag */
+#define M6811_WCOL      0x40    /* Write Collision */
+#define M6811_MODF      0x10    /* Mode Fault */
+
+/* Flags of the ADCTL register.  */
+#define M6811_CCF       0x80    /* Conversions Complete Flag */
+#define M6811_SCAN      0x20    /* Continuous Scan Control */
+#define M6811_MULT      0x10    /* Multiple Channel/Single Channel Control */
+#define M6811_CD        0x08    /* Channel Select D */
+#define M6811_CC        0x04    /*                C */
+#define M6811_CB        0x02    /*                B */
+#define M6811_CA        0x01    /*                A */
+
+/* Flags of the CFORC register.  */
+#define M6811_FOC1      0x80    /* Force Output Compare 1 */
+#define M6811_FOC2      0x40    /*                      2 */
+#define M6811_FOC3      0x20    /*                      3 */
+#define M6811_FOC4      0x10    /*                      4 */
+#define M6811_FOC5      0x08    /*                      5 */
+
+/* Flags of the OC1M register.  */
+#define M6811_OC1M7     0x80    /* Output Compare 7 */
+#define M6811_OC1M6     0x40    /*                6 */
+#define M6811_OC1M5     0x20    /*                5 */
+#define M6811_OC1M4     0x10    /*                4 */
+#define M6811_OC1M3     0x08    /*                3 */
+
+/* Flags of the OC1D register.  */
+#define M6811_OC1D7     0x80
+#define M6811_OC1D6     0x40
+#define M6811_OC1D5     0x20
+#define M6811_OC1D4     0x10
+#define M6811_OC1D3     0x08
+
+/* Flags of the TCTL1 register.  */
+#define M6811_OM2       0x80    /* Output Mode 2 */
+#define M6811_OL2       0x40    /* Output Level 2 */
+#define M6811_OM3       0x20
+#define M6811_OL3       0x10
+#define M6811_OM4       0x08
+#define M6811_OL4       0x04
+#define M6811_OM5       0x02
+#define M6811_OL5       0x01
+
+/* Flags of the TCTL2 register.  */
+#define M6811_EDG1B     0x20    /* Input Edge Capture Control 1 */
+#define M6811_EDG1A     0x10
+#define M6811_EDG2B     0x08    /* Input 2 */
+#define M6811_EDG2A     0x04
+#define M6811_EDG3B     0x02    /* Input 3 */
+#define M6811_EDG3A     0x01
+
+/* Flags of the TMSK1 register.  */
+#define M6811_OC1I      0x80    /* Output Compare 1 Interrupt */
+#define M6811_OC2I      0x40    /*                2           */
+#define M6811_OC3I      0x20    /*                3           */
+#define M6811_OC4I      0x10    /*                4           */
+#define M6811_OC5I      0x08    /*                5           */
+#define M6811_IC1I      0x04    /* Input Capture  1 Interrupt */
+#define M6811_IC2I      0x02    /*                2           */
+#define M6811_IC3I      0x01    /*                3           */
+
+/* Flags of the TFLG1 register.  */
+#define M6811_OC1F      0x80    /* Output Compare 1 Flag */
+#define M6811_OC2F      0x40    /*                2      */
+#define M6811_OC3F      0x20    /*                3      */
+#define M6811_OC4F      0x10    /*                4      */
+#define M6811_OC5F      0x08    /*                5      */
+#define M6811_IC1F      0x04    /* Input Capture  1 Flag */
+#define M6811_IC2F      0x02    /*                2      */
+#define M6811_IC3F      0x01    /*                3      */
+
+/* Flags of Timer Interrupt Mask Register 2 (TMSK2).  */
+#define M6811_TOI       0x80    /* Timer Overflow Interrupt Enable */
+#define M6811_RTII      0x40    /* RTI Interrupt Enable */
+#define M6811_PAOVI     0x20    /* Pulse Accumulator Overflow Interrupt En. */
+#define M6811_PAII      0x10    /* Pulse Accumulator Interrupt Enable */
+#define M6811_PR1       0x02    /* Timer prescaler */
+#define M6811_PR0       0x01    /* Timer prescaler */
+#define M6811_TPR_1     0x00    /* " " prescale div 1 */
+#define M6811_TPR_4     0x01    /* " " prescale div 4 */
+#define M6811_TPR_8     0x02    /* " " prescale div 8 */
+#define M6811_TPR_16    0x03    /* " " prescale div 16 */
+
+/* Flags of Timer Interrupt Flag Register 2 (M6811_TFLG2).  */
+#define M6811_TOF       0x80    /* Timer overflow bit */
+#define M6811_RTIF      0x40    /* Read time interrupt flag */
+#define M6811_PAOVF     0x20    /* Pulse accumulator overflow Interrupt flag */
+#define M6811_PAIF      0x10    /* Pulse accumulator Input Edge " " " */
+
+/* Flags of Pulse Accumulator Control Register (PACTL).  */
+#define M6811_DDRA7     0x80    /* Data direction for port A bit 7 */
+#define M6811_PAEN      0x40    /* Pulse accumulator system enable */
+#define M6811_PAMOD     0x20    /* Pulse accumulator mode */
+#define M6811_PEDGE     0x10    /* Pulse accumulator edge control */
+#define M6811_RTR1      0x02    /* RTI Interrupt rates select */
+#define M6811_RTR0      0x01    /* " " " " */
+
+/* Flags of the Options register.  */
+#define M6811_ADPU      0x80    /* A/D Powerup */
+#define M6811_CSEL      0x40    /* A/D/EE Charge pump clock source select */
+#define M6811_IRQE      0x20    /* IRQ Edge/Level sensitive */
+#define M6811_DLY       0x10    /* Stop exit turn on delay */
+#define M6811_CME       0x08    /* Clock Monitor enable */
+#define M6811_CR1       0x02    /* COP timer rate select */
+#define M6811_CR0       0x01    /* COP timer rate select */
+
+/* Flags of the HPRIO register.  */
+#define M6811_RBOOT     0x80    /* Read Bootstrap ROM */
+#define M6811_SMOD      0x40    /* Special Mode */
+#define M6811_MDA       0x20    /* Mode Select A */
+#define M6811_IRV       0x10    /* Internal Read Visibility */
+#define M6811_PSEL3     0x08    /* Priority Select */
+#define M6811_PSEL2     0x04
+#define M6811_PSEL1     0x02
+#define M6811_PSEL0     0x01
+
+#define M6811_IO_SIZE   (0x40)
+
+/* The I/O registers are represented by a volatile array.
+   Address if fixed at link time.  */
+extern volatile unsigned char _io_ports[];
+
+
+extern unsigned short get_timer_counter (void);
+extern void set_timer_counter (unsigned short);
+extern unsigned short get_input_capture_1 (void);
+extern void set_input_capture_1 (unsigned short);
+extern unsigned short get_input_capture_2 (void);
+extern void set_input_capture_2 (unsigned short);
+extern unsigned short get_input_capture_3 (void);
+extern void set_input_capture_3 (unsigned short);
+extern unsigned short get_output_compare_1 (void);
+extern void set_output_compare_1 (unsigned short);
+extern unsigned short get_output_compare_2 (void);
+extern void set_output_compare_2 (unsigned short);
+extern unsigned short get_output_compare_3 (void);
+extern void set_output_compare_3 (unsigned short);
+extern unsigned short get_output_compare_4 (void);
+extern void set_output_compare_4 (unsigned short);
+extern unsigned short get_output_compare_5 (void);
+extern void set_output_compare_5 (unsigned short);
+extern void set_bus_expanded (void);
+extern void set_bus_single_chip (void);
+extern void cop_reset (void);
+extern void cop_optional_reset (void);
+extern void timer_acknowledge (void);
+extern void timer_initialize_rate (unsigned char);
+
+
+extern inline unsigned short
+get_timer_counter (void)
+{
+  return ((unsigned volatile short*) &_io_ports[M6811_TCTN_H])[0];
+}
+
+extern inline void
+set_timer_counter (unsigned short value)
+{
+  ((unsigned volatile short*) &_io_ports[M6811_TCTN_H])[0] = value;
+}
+
+extern inline unsigned short
+get_input_capture_1 (void)
+{
+  return ((unsigned volatile short*) &_io_ports[M6811_TIC1_H])[0];
+}
+
+extern inline void
+set_input_capture_1 (unsigned short value)
+{
+  ((unsigned volatile short*) &_io_ports[M6811_TIC1_H])[0] = value;
+}
+
+extern inline unsigned short
+get_input_capture_2 (void)
+{
+  return ((unsigned volatile short*) &_io_ports[M6811_TIC2_H])[0];
+}
+
+extern inline void
+set_input_capture_2 (unsigned short value)
+{
+  ((unsigned volatile short*) &_io_ports[M6811_TIC2_H])[0] = value;
+}
+
+extern inline unsigned short
+get_input_capture_3 (void)
+{
+  return ((unsigned volatile short*) &_io_ports[M6811_TIC3_H])[0];
+}
+
+extern inline void
+set_input_capture_3 (unsigned short value)
+{
+  ((unsigned volatile short*) &_io_ports[M6811_TIC3_H])[0] = value;
+}
+
+/* Get output compare 16-bit register.  */
+extern inline unsigned short
+get_output_compare_1 (void)
+{
+  return ((unsigned volatile short*) &_io_ports[M6811_TOC1_H])[0];
+}
+
+extern inline void
+set_output_compare_1 (unsigned short value)
+{
+  ((unsigned volatile short*) &_io_ports[M6811_TOC1_H])[0] = value;
+}
+
+extern inline unsigned short
+get_output_compare_2 (void)
+{
+  return ((unsigned volatile short*) &_io_ports[M6811_TOC2_H])[0];
+}
+
+extern inline void
+set_output_compare_2 (unsigned short value)
+{
+  ((unsigned volatile short*) &_io_ports[M6811_TOC2_H])[0] = value;
+}
+
+extern inline unsigned short
+get_output_compare_3 (void)
+{
+  return ((unsigned volatile short*) &_io_ports[M6811_TOC3_H])[0];
+}
+
+extern inline void
+set_output_compare_3 (unsigned short value)
+{
+  ((unsigned volatile short*) &_io_ports[M6811_TOC3_H])[0] = value;
+}
+
+extern inline unsigned short
+get_output_compare_4 (void)
+{
+  return ((unsigned volatile short*) &_io_ports[M6811_TOC4_H])[0];
+}
+
+extern inline void
+set_output_compare_4 (unsigned short value)
+{
+  ((unsigned volatile short*) &_io_ports[M6811_TOC4_H])[0] = value;
+}
+
+extern inline unsigned short
+get_output_compare_5 (void)
+{
+  return ((unsigned volatile short*) &_io_ports[M6811_TOC5_H])[0];
+}
+
+extern inline void
+set_output_compare_5 (unsigned short value)
+{
+  ((unsigned volatile short*) &_io_ports[M6811_TOC5_H])[0] = value;
+}
+
+
+/* Set the board in the expanded mode to get access to external bus.  */
+extern inline void
+set_bus_expanded (void)
+{
+  _io_ports[M6811_HPRIO] |= M6811_MDA;
+}
+
+
+/* Set the board in single chip mode.  */
+extern inline void
+set_bus_single_chip (void)
+{
+  _io_ports[M6811_HPRIO] &= ~M6811_MDA;
+}
+
+/* Reset the COP.  */
+extern inline void
+cop_reset (void)
+{
+  _io_ports[M6811_COPRST] = 0x55;
+  _io_ports[M6811_COPRST] = 0xAA;
+}
+
+extern inline void
+cop_optional_reset (void)
+{
+#if defined(M6811_USE_COP) && M6811_USE_COP == 1
+  cop_reset ();
+#endif
+}
+
+/* Acknowledge the timer interrupt.  */
+extern inline void
+timer_acknowledge (void)
+{
+  _io_ports[M6811_TFLG2] = M6811_RTIF;
+}
+
+/* Initialize the timer.  */
+extern inline void
+timer_initialize_rate (unsigned char divisor)
+{
+  _io_ports[M6811_TMSK2] = M6811_RTII | divisor;
+}
+
+
+#ifdef __cplusplus
+};
+#endif
+  
+#endif /* _M68HC11_PORTS_H */
index 4584f5e..7094266 100644 (file)
@@ -1,6 +1,8 @@
 #ifndef _VEND_H_
 #define _VEND_H_
 
+#include "ports.h"
+
 /* FIXME: are these typedefs right for m68hc11-gcc? */
 typedef unsigned char    u8;
 typedef signed char      s8;
@@ -11,6 +13,16 @@ typedef signed long      s32;
 typedef u8               bool;
 typedef u16           addr_t;
 
+/* addresses of these set at link time */
+#define buffered_addr_h(a) \
+       extern volatile u8* _##a
+
+buffered_addr_h(switch_input);
+buffered_addr_h(misc_input);
+buffered_addr_h(home_sensors);
+buffered_addr_h(changer_output);
+buffered_addr_h(misc_output);
+
 /******* from display.c *******/
 
 /* scrolling modes */
@@ -20,31 +32,16 @@ typedef u16           addr_t;
 
 extern char current_message[1024];
 
+void display_init();
 void set_msg(char* newmsg);
 void set_wrap_mode(u8 new_wrap_mode);
 void display_refresh();
 
-/******* from helpers.c *******/
-#define buffered_port_h(p) \
-       void outb_##p(u8 b); \
-       void bset_##p(u8 mask); \
-       void bclr_##p(u8 mask);
-
-void outb(u16 port, u8 byte);
-void bset(u16 addr, u8 mask);
-void bclr(u16 addr, u8 mask);
-
-buffered_port_h(3800);
-
 void delay(u16 ms);
 
-/******** Some IO Ports ******/
-#define PORTA             0x1000
+/******** Some meaningful bits ******/
 #define PORTA_DISP_RESET    0x80 /* active low */
 
-#define SPCR              0x1028 /* Serial Peripheral Control Register */
-#define SPCR_SPE            0x40 /* Serial Peripheral System Enable    */
-
 /* Address 3800 bits */
 #define A3800_DISPLAY_WRITE  0x04
 

UCC git Repository :: git.ucc.asn.au