OpenCores
URL https://opencores.org/ocsvn/openmsp430/openmsp430/trunk

Subversion Repositories openmsp430

[/] [openmsp430/] [trunk/] [core/] [sim/] [rtl_sim/] [src-c/] [sandbox/] [main.c] - Blame information for rev 76

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 76 olivier.gi
/*===========================================================================*/
2
/* Copyright (C) 2001 Authors                                                */
3
/*                                                                           */
4
/* This source file may be used and distributed without restriction provided */
5
/* that this copyright statement is not removed from the file and that any   */
6
/* derivative work contains the original copyright notice and the associated */
7
/* disclaimer.                                                               */
8
/*                                                                           */
9
/* This source file is free software; you can redistribute it and/or modify  */
10
/* it under the terms of the GNU Lesser General Public License as published  */
11
/* by the Free Software Foundation; either version 2.1 of the License, or    */
12
/* (at your option) any later version.                                       */
13
/*                                                                           */
14
/* This source is distributed in the hope that it will be useful, but WITHOUT*/
15
/* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or     */
16
/* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public       */
17
/* License for more details.                                                 */
18
/*                                                                           */
19
/* You should have received a copy of the GNU Lesser General Public License  */
20
/* along with this source; if not, write to the Free Software Foundation,    */
21
/* Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA        */
22
/*                                                                           */
23
/*===========================================================================*/
24
/*                                 SANDBOX                                   */
25
/*---------------------------------------------------------------------------*/
26
/*                                                                           */
27
/* Author(s):                                                                */
28
/*             - Olivier Girard,    olgirard@gmail.com                       */
29
/*                                                                           */
30
/*---------------------------------------------------------------------------*/
31
/* $Rev: 19 $                                                                */
32
/* $LastChangedBy: olivier.girard $                                          */
33
/* $LastChangedDate: 2009-08-04 23:47:15 +0200 (Tue, 04 Aug 2009) $          */
34
/*===========================================================================*/
35
 
36
#include <msp430x11x1.h>
37
#include <signal.h>                    // Needed for using interrupts with msp430-gcc
38
 
39
 
40
volatile char shift_direction = 0x01;  // Global variable
41
 
42
int main(void) {
43
 
44
    WDTCTL = WDTPW | WDTHOLD;          // Disable watchdog timer
45
 
46
    P2DIR  = 0xff;                     // Port 2.0-2.7 = output
47
    P2OUT  = shift_direction;          // Initialize Port 2
48
 
49
    P1DIR  = 0x00;                     // Port 1.0-1.7 = input
50
    P1IE   = 0x01;                     // Port 1.0 interrupt enabled
51
    P1IES  = 0x00;                     // Port 1.0 interrupt edge selection (0=pos 1=neg)
52
    P1IFG  = 0x00;                     // Clear all Port 1 interrupt flags (just in case)
53
 
54
    eint();                            // Enable interrupts
55
 
56
    while (1) {
57
      if (P2OUT == 0x00) {
58
        P2OUT = shift_direction;
59
 
60
      } else if (shift_direction == 0x01) {
61
        P2OUT = (P2OUT << 1);
62
 
63
      } else {
64
        P2OUT = (P2OUT >> 1);
65
      }
66
    }
67
}
68
 
69
 // Port1 Interrupt Service Routine using msp430-gcc
70
interrupt(PORT1_VECTOR) port1_isr(void) {
71
   if (P1IFG & 0x01) {
72
     shift_direction ^=  0x81;
73
     P1IFG           &= ~0x01;         // Clear Port 1.0 interrupt flag
74
   }
75
}

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.