Contiki 2.6

spix.c

00001 /*
00002  * Copyright (c) 2006, Swedish Institute of Computer Science
00003  * All rights reserved.
00004  *
00005  * Redistribution and use in source and binary forms, with or without
00006  * modification, are permitted provided that the following conditions
00007  * are met:
00008  * 1. Redistributions of source code must retain the above copyright
00009  *    notice, this list of conditions and the following disclaimer.
00010  * 2. Redistributions in binary form must reproduce the above copyright
00011  *    notice, this list of conditions and the following disclaimer in the
00012  *    documentation and/or other materials provided with the distribution.
00013  * 3. Neither the name of the Institute nor the names of its contributors
00014  *    may be used to endorse or promote products derived from this software
00015  *    without specific prior written permission.
00016  *
00017  * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
00018  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00019  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
00020  * ARE DISCLAIMED.  IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
00021  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
00022  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
00023  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
00024  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00025  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
00026  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
00027  * SUCH DAMAGE.
00028  *
00029  * @(#)$Id: spix.c,v 1.1 2010/08/24 16:23:20 joxe Exp $
00030  */
00031 
00032 #include "contiki-conf.h"
00033 
00034 /*
00035  * This is SPI initialization code for the MSP430X architecture.
00036  *
00037  */
00038 /* unsigned char spi_busy = 0; */
00039 /*---------------------------------------------------------------------------*/
00040 /*
00041  * Initialize SPI bus.
00042  */
00043 void
00044 spi_init(void)
00045 {
00046   /* Initalize ports for communication with SPI units. */
00047 
00048   UCB0CTL1 |= UCSWRST;                /* Reset USCI */
00049   UCB0CTL1 |= UCSSEL_2;               /* smclk while usci is reset */
00050   /* MSB-first 8-bit, Master, Synchronous, 3 pin SPI master, no ste,
00051      watch-out for clock-phase UCCKPH */
00052   UCB0CTL0 = (UCMSB | UCMST | UCSYNC | UCCKPL);
00053 
00054   /* Set up SPI bus speed. */
00055   UCB0BR1 = 0x00;
00056   UCB0BR0 = 0x01;
00057 
00058   /* Dont need modulation control. */
00059   /* UCB0MCTL = 0; */
00060 
00061   /* Select Peripheral functionality */
00062   P3SEL |= BV(SCK) | BV(MOSI) | BV(MISO);
00063   /* Configure as outputs(SIMO,CLK). */
00064   P3DIR |= BV(SCK) | BV(MISO);
00065 
00066   /* Clear pending interrupts before enabling. */
00067   UCB0IE &= ~UCRXIFG;
00068   UCB0IE &= ~UCTXIFG;
00069   /* Remove RESET before enabling interrupts */
00070   UCB0CTL1 &= ~UCSWRST;
00071 
00072   /* Enable UCB0 Interrupts */
00073   /* Enable USCI_B0 TX Interrupts */
00074   /* IE2 |= UCB0TXIE; */
00075   /* Enable USCI_B0 RX Interrupts */
00076   /* IE2 |= UCB0RXIE; */
00077 }
00078 /*---------------------------------------------------------------------------*/