1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/boards/pttu/board_init.c

180 lines
4.6 KiB
C
Raw Normal View History

2014-01-20 19:39:00 +01:00
/*
* Copyright (C) 2013 Freie Universität Berlin
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
2014-01-20 19:39:00 +01:00
*/
/**
2015-02-12 13:44:41 +01:00
* @ingroup boards_pttu
* @{
*/
/**
* @file
2014-01-20 19:39:00 +01:00
* @brief PTTU board initialization
*
2014-01-20 19:39:00 +01:00
* @author Heiko Will
* @author Kaspar Schleiser
*
*/
2013-12-16 17:54:58 +01:00
#include "board.h"
2014-01-20 19:39:00 +01:00
#include "msba2_common.h"
2013-12-16 17:54:58 +01:00
#include "VIC.h"
#include "cpu.h"
#define CL_CPU_DIV 4
2014-01-20 19:39:00 +01:00
/*---------------------------------------------------------------------------*/
void init_clks1(void)
{
/* Disconnect PLL */
PLLCON &= ~0x0002;
pllfeed();
while (PLLSTAT & BIT25) {} /* wait until PLL is disconnected before disabling - deadlock otherwise */
2014-01-20 19:39:00 +01:00
/* Disable PLL */
PLLCON &= ~0x0001;
pllfeed();
while (PLLSTAT & BIT24) {} /* wait until PLL is disabled */
2014-01-20 19:39:00 +01:00
SCS |= 0x20; /* Enable main OSC */
while( !(SCS & 0x40) ) {} /* Wait until main OSC is usable */
2014-01-20 19:39:00 +01:00
/* select main OSC, 16MHz, as the PLL clock source */
CLKSRCSEL = 0x0001;
2014-01-20 19:39:00 +01:00
/* Setting Multiplier and Divider values */
PLLCFG = 0x0008; /* M=9 N=1 Fcco = 288 MHz */
pllfeed();
2014-01-20 19:39:00 +01:00
/* Enabling the PLL */
PLLCON = 0x0001;
pllfeed();
2014-01-20 19:39:00 +01:00
/* Set clock divider to 4 (value+1) */
CCLKCFG = CL_CPU_DIV - 1; /* Fcpu = 72 MHz */
2014-01-20 19:39:00 +01:00
#if USE_USB
USBCLKCFG = USBCLKDivValue; /* usbclk = 288 MHz/6 = 48 MHz */
2014-01-20 19:39:00 +01:00
#endif
}
void bl_init_ports(void)
{
gpio_init_ports();
/* UART0 */
PINSEL0 |= BIT4 + BIT6; /* RxD0 and TxD0 */
PINSEL0 &= ~(BIT5 + BIT7);
/* Turn Board on */
PINMODE0 |= BIT1;
FIO0DIR |= BIT27;
FIO0CLR = BIT27;
/* 5V*/
FIO1DIR |= BIT28; /* Synch */
FIO1SET = BIT28; /* No Powersave */
FIO1DIR |= BIT27; /* 5V off */
FIO1CLR = BIT27;
/* Disable Resistors on Buttons */
PINMODE4 |= BIT9 + BIT11;
/* Disable Resistors on LED - and Ports to output*/
PINMODE7 |= BIT19 + BIT21;
PINMODE2 |= BIT1;
FIO1DIR |= BIT0;
FIO3DIR |= BIT25 + BIT26;
FIO1SET = BIT0;
FIO3SET = BIT25 + BIT26;
/* Config and Disable PA */
FIO1DIR |= BIT25 + BIT26 + BIT22;
FIO1SET = BIT26;
FIO1CLR = BIT25;
FIO1CLR = BIT22; /* PA /Shutdown */
FIO0DIR |= BIT26; /* ** Important: First put this Port as DA 2.0V and then turn on PA!! */
FIO0SET = BIT26; /* ** */
/* Configure GPS */
PINMODE3 |= BIT3 + BIT7; /* No Pullup on 1.17 & 1.19 */
PINMODE9 |= BIT27 + BIT25; /* No Pullup for Uart */
FIO1DIR |= BIT17;
FIO1CLR = BIT17; /* Turn off GPS */
FIO1DIR |= BIT19;
FIO1CLR = BIT19; /* Hold in Reset */
PINSEL9 |= BIT24 + BIT25 + BIT26 + BIT27; /* 4.28 & 4.29 as Uart3 */
/* Nanotron */
FIO2DIR &= ~BIT8; /* nanotron uC IRQ as input */
FIO1DIR |= BIT15; /* nanotron power on reset */
FIO1DIR &= ~BIT14; /* nanotron uC RESET as input */
FIO1DIR &= ~BIT10; /* nanotron uC Vcc as input */
FIO1DIR |= BIT9; /* nanotron ENABLE as output */
FIO1DIR &= ~BIT4; /* nanotron Rx/Tx as input */
FIO1CLR = BIT15;
FIO1CLR = BIT9; /* Enable power */
PINMODE1 |= BIT1; /* No Pullup for CS */
FIO0DIR |= BIT16; /* CS as output */
FIO0SET = BIT16; /* drive cs inactive */
FIO0DIR |= BIT18 + BIT15; /* SPi Output */
/* RFID */
FIO1DIR |= BIT1; /* RFID Power */
FIO1CLR = BIT1; /* */
FIO0DIR |= BIT1; /* RFID Reset */
FIO0SET = BIT1; /* Hold in Reset */
FIO0DIR &= ~BIT10; /* LED as INPUT */
FIO0DIR &= ~BIT11; /* DATA as INPUT */
PINMODE0 |= BIT19 + BIT21; /* No Pullups */
/* LTC4150 ARM */
FIO0DIR |= BIT5;
FIO0CLR = BIT5;
/* LTC4150 System */
FIO0DIR |= BIT24;
FIO0CLR = BIT24;
/* Battery Voltage (AD) */
PINMODE1 |= BIT19;
PINSEL1 &= ~BIT19;
PINSEL1 |= BIT18;
/*cc1100 */
FIO0DIR |= BIT6 + BIT7 + BIT9;
FIO0SET = BIT6;
FIO0SET = BIT7 + BIT9;
/*SD */
FIO2DIR |= BIT12 + BIT13 + BIT11;
FIO0DIR |= BIT20 + BIT22 + BIT21;
/*Tetra */
FIO2DIR |= BIT0 + BIT7;
/* No Pullups on any port */
int nopullup = BIT1 + BIT3 + BIT5 + BIT7 + BIT9 + BIT11 + BIT13 + BIT15 + BIT17 + BIT19 + BIT21 + BIT23 + BIT25 + BIT27 + BIT29 + BIT31;
PINMODE0 = nopullup - BIT13 - BIT15 - BIT17 - BIT19;
PINMODE1 = BIT1 + BIT3 + BIT5 + BIT7 + BIT9 + BIT11 + BIT13 + BIT15 + BIT17 + BIT19 + BIT21;
PINMODE2 = nopullup;
PINMODE3 = nopullup;
PINMODE4 = nopullup;
PINMODE5 = nopullup;
PINMODE6 = nopullup;
PINMODE7 = nopullup;
PINMODE8 = nopullup;
PINMODE9 = nopullup;
}
/** @} */