📄 maintutorial4local.c
字号:
/*****************************************************************************
*
* File: maintutorial4local.c
*
* Copyright S. Brennen Ball, 2007
*
* The author provides no guarantees, warantees, or promises, implied or
* otherwise. By using this software you agree to indemnify the author
* of any damages incurred by using it.
*
*****************************************************************************/
#include "lpc214x.h"
#include "spi1.h"
#include "delays.h"
#include "nrf24l01.h"
#include "uart0.h"
//for the following 9 definitions, see Jim Lynch's ARM tutorial
#define PLOCK 0x400
void Initialize();
void InitializePLL();
void InitializeIO();
void Feed();
void IRQ_Routine() __attribute__ ((interrupt("IRQ")));
void FIQ_Routine() __attribute__ ((interrupt("FIQ")));
void SWI_Routine() __attribute__ ((interrupt("SWI")));
void UNDEF_Routine() __attribute__ ((interrupt("UNDEF")));
//end Jim Lynch's definitions
void ToggleLED(); //toggle the current state of the on-board LED
#define keylen 3 //length of the key
unsigned char key[keylen] = {'K', 'e', 'y'}; //bytes of the key
//main routine
int main()
{
unsigned int i; //general counter variable
unsigned char curseq = 0; //keeps the current expected packet number
unsigned char data[2]; //array to hold the encrypted byte and packet count
Initialize(); //initialize IO, UART, SPI, set up nRF24L01 as TX, execute KSA
while(1)
{
//wait until a packet has been received
while(!(nrf24l01_irq_pin_active() && nrf24l01_irq_rx_dr_active()));
nrf24l01_irq_clear_all(); //clear all interrupts in the 24L01
nrf24l01_read_rx_payload(data, 2); //get the payload into data
//printf doesn't print the leading 0 if a hex number is less than 0x10, so print it manually
if(data[0] < 0x10)
uart0_printf("0");
uart0_printf("%x: ", data[0]); //print out the received encrypted character
//catch up to the correct location in the S array by executing the PRGA
if(data[1] != curseq)
{
for(i = 0; i < data[1] - curseq; i++)
arc4_get_prga_byte();
}
arc4_decrypt(data, 1); //decrypt the data received
uart0_printf("%c\r\n", data[0]); //print out the decrypted character
curseq = data[1] + 1; //increase the value of the expected next packet
ToggleLED(); //toggle the on-board LED as visual indication that the loop has completed
}
}
//initialize routine
void Initialize()
{
InitializePLL(); //initialize PLL (Jim Lynch function)
InitializeIO(); //set up IO (directions and functions)
uart0_open(); //open UART0
spi1_open(); //open SPI1
nrf24l01_initialize_debug(true, 2, false); //initialize the 24L01 to the debug configuration as TX, 1 data byte, and auto-ack disabled
arc4_initialize_ksa(key, keylen); //execute the KSA
}
//initialize IO pins
void InitializeIO()
{
SCS = 0x03; // select the "fast" version of the I/O ports
FIO1DIR3 = 0x01; //set LED bit as output
FIO1PIN3 = 0x00; //turn LED on (pin is 0)
FIO0DIR = 0x007A0001; //set CE, CSN, MISO1, SCK1, and TX as outputs (and another control bit on my particular board)
FIO0PIN = 0x00500000; //set CSN bit (and another control bit on my particular board)
PINSEL0 = 0x00000005; //set up UART0 pins as UART0 instead of GPIO
PINSEL1 = 0x000000A8; //set up SPI1 pins as SPI1 instead of GPIO
}
//toggles on-board LED
void ToggleLED()
{
if((FIO1PIN3 & 0x01) == 0x00)
FIO1PIN3 = 0x01;
else
FIO1PIN3 = 0x00;
}
//initialize PLL to 5x (Jim Lynch function)
void InitializePLL()
{
// Setting Multiplier and Divider values
PLLCFG=0x24;
Feed();
// Enabling the PLL */
PLLCON=0x1;
Feed();
// Wait for the PLL to lock to set frequency
while(!(PLLSTAT & PLOCK));
// Connect the PLL as the clock source
PLLCON=0x3;
Feed();
// Enabling MAM and setting number of clocks used for Flash memory fetch (4 cclks in this case)
MAMCR=0x2;
MAMTIM=0x4;
VPBDIV=0x01;
}
//operate PLL Feed (Jim Lynch function)
void Feed()
{
PLLFEED=0xAA;
PLLFEED=0x55;
}
//the following 4 stubs are functions by Jim Lynch
void IRQ_Routine()
{
}
void FIQ_Routine()
{
}
void SWI_Routine()
{
}
void UNDEF_Routine()
{
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -