174 lines
3.7 KiB
C
174 lines
3.7 KiB
C
|
/*
|
||
|
* File : board.c
|
||
|
* This file is part of RT-Thread RTOS
|
||
|
* COPYRIGHT (C) 2006, RT-Thread Develop Team
|
||
|
*
|
||
|
* The license and distribution terms for this file may be
|
||
|
* found in the file LICENSE in this distribution or at
|
||
|
* http://openlab.rt-thread.com/license/LICENSE
|
||
|
*
|
||
|
* Change Logs:
|
||
|
* Date Author Notes
|
||
|
* 2006-08-23 Bernard first implementation
|
||
|
*/
|
||
|
|
||
|
#include <rtthread.h>
|
||
|
#include <rthw.h>
|
||
|
|
||
|
#include <AT91SAM7X.h>
|
||
|
#include "board.h"
|
||
|
|
||
|
static void rt_hw_board_led_init(void);
|
||
|
|
||
|
/**
|
||
|
* @addtogroup sam7s
|
||
|
*/
|
||
|
/*@{*/
|
||
|
|
||
|
/* Periodic Interval Value */
|
||
|
#define PIV (((MCK/16)/1000)*(1000/RT_TICK_PER_SECOND))
|
||
|
|
||
|
/**
|
||
|
* This is the timer interrupt service routine.
|
||
|
* @param vector the irq number for timer
|
||
|
*/
|
||
|
void rt_hw_timer_handler(int vector)
|
||
|
{
|
||
|
if (AT91C_PITC_PISR & 0x01)
|
||
|
{
|
||
|
/* increase a tick */
|
||
|
rt_tick_increase();
|
||
|
|
||
|
/* ack interrupt */
|
||
|
AT91C_AIC_EOICR = AT91C_PITC_PIVR;
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
/* end of interrupt */
|
||
|
AT91C_AIC_EOICR = 0;
|
||
|
}
|
||
|
}
|
||
|
/* PIO Flash PA PB PIN */
|
||
|
#define LED1 (1 << 19) /* PA0 / PGMEN0 & PWM0 TIOA0 48 */
|
||
|
#define LED2 (1 << 20) /* PA1 / PGMEN1 & PWM1 TIOB0 47 */
|
||
|
#define LED3 (1 << 21) /* PA2 & PWM2 SCK0 44 */
|
||
|
#define LED4 (1 << 22) /* PA3 & TWD NPCS3 43 */
|
||
|
#define LED_MASK (LED1|LED2|LED3|LED4)
|
||
|
|
||
|
int leds[] = {LED1, LED2, LED3, LED4};
|
||
|
|
||
|
/**
|
||
|
* This function will init led on the board
|
||
|
*/
|
||
|
static void rt_hw_board_led_init()
|
||
|
{
|
||
|
/* enable the clock of the PIO A, PIO B */
|
||
|
AT91C_PMC_PCER = 1 << AT91C_ID_PIOA | 1 << AT91C_ID_PIOB;
|
||
|
|
||
|
/* configure PIO as output for led */
|
||
|
AT91C_PIOB_PER = LED_MASK;
|
||
|
AT91C_PIOB_OER = LED_MASK;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* This function will take the led on board on.
|
||
|
*
|
||
|
* @param n the number nth led
|
||
|
*/
|
||
|
void rt_hw_board_led_on(int n)
|
||
|
{
|
||
|
if (n >= 0 && n < 4)
|
||
|
{
|
||
|
AT91C_PIOB_CODR = leds[n];
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* This function will take the led on board off.
|
||
|
*
|
||
|
* @param n the number nth led
|
||
|
*/
|
||
|
void rt_hw_board_led_off(int n)
|
||
|
{
|
||
|
if (n >= 0 && n < 4)
|
||
|
{
|
||
|
AT91C_PIOB_SODR = leds[n];
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/*
|
||
|
* RT-Thread Console Interface, used by rt_kprintf
|
||
|
*/
|
||
|
/**
|
||
|
* This function is used to display a string on console, normally, it's
|
||
|
* invoked by rt_kprintf
|
||
|
*
|
||
|
* @param str the displayed string
|
||
|
*/
|
||
|
void rt_hw_console_output(const char* str)
|
||
|
{
|
||
|
while (*str)
|
||
|
{
|
||
|
if (*str == '\n')
|
||
|
{
|
||
|
while (!(AT91C_US0_CSR & AT91C_US_TXRDY));
|
||
|
AT91C_US0_THR = '\r';
|
||
|
}
|
||
|
|
||
|
/* Wait for Empty Tx Buffer */
|
||
|
while (!(AT91C_US0_CSR & AT91C_US_TXRDY));
|
||
|
/* Transmit Character */
|
||
|
AT91C_US0_THR = *str;
|
||
|
|
||
|
str ++;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
static void rt_hw_console_init()
|
||
|
{
|
||
|
/* Enable Clock for USART0 */
|
||
|
AT91C_PMC_PCER = 1 << AT91C_ID_US0;
|
||
|
/* Enable RxD0 and TxDO Pin */
|
||
|
AT91C_PIO_PDR = (1 << 5) | (1 << 6);
|
||
|
|
||
|
AT91C_US0_CR = AT91C_US_RSTRX | /* Reset Receiver */
|
||
|
AT91C_US_RSTTX | /* Reset Transmitter */
|
||
|
AT91C_US_RXDIS | /* Receiver Disable */
|
||
|
AT91C_US_TXDIS; /* Transmitter Disable */
|
||
|
|
||
|
AT91C_US0_MR = AT91C_US_USMODE_NORMAL | /* Normal Mode */
|
||
|
AT91C_US_CLKS_CLOCK | /* Clock = MCK */
|
||
|
AT91C_US_CHRL_8_BITS | /* 8-bit Data */
|
||
|
AT91C_US_PAR_NONE | /* No Parity */
|
||
|
AT91C_US_NBSTOP_1_BIT; /* 1 Stop Bit */
|
||
|
|
||
|
/* set baud rate divisor */
|
||
|
AT91C_US0_BRGR = BRD;
|
||
|
|
||
|
AT91C_US0_CR = AT91C_US_RXEN | /* Receiver Enable */
|
||
|
AT91C_US_TXEN; /* Transmitter Enable */
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* This function will initial sam7x board.
|
||
|
*/
|
||
|
void rt_hw_board_init()
|
||
|
{
|
||
|
extern void rt_serial_init(void);
|
||
|
|
||
|
/* init hardware console */
|
||
|
rt_hw_console_init();
|
||
|
|
||
|
/* init led */
|
||
|
rt_hw_board_led_init();
|
||
|
|
||
|
/* init PITC */
|
||
|
AT91C_PITC_PIMR = (1 << 25) | (1 << 24) | PIV;
|
||
|
|
||
|
/* install timer handler */
|
||
|
rt_hw_interrupt_install(AT91C_ID_SYS, rt_hw_timer_handler, RT_NULL);
|
||
|
AT91C_AIC_SMR(AT91C_ID_SYS) = 0;
|
||
|
rt_hw_interrupt_umask(AT91C_ID_SYS);
|
||
|
}
|
||
|
/*@}*/
|