Merge branch 'master' of github.com:r0ket/r0ket

This commit is contained in:
schneider 2011-08-09 18:16:11 +02:00
commit d4a0cdb4c2
8 changed files with 334 additions and 85 deletions

View file

@ -10,8 +10,12 @@ VPATH +=
OBJS += main.o OBJS += main.o
ifeq "$(wildcard table.c)" "table.c" ifeq "$(wildcard table.c)" "table.c"
ifeq "$(APP)" "serial"
OBJS +=
else
OBJS += table.o OBJS += table.o
endif endif
endif
LIBS += lcd/liblcd.a LIBS += lcd/liblcd.a
LIBS += basic/libbasic.a LIBS += basic/libbasic.a

View file

@ -1,11 +1,18 @@
i: initialize i: initialize
cb / cm / cr: config funk for beacon/mesh/remote pb: preset funk for beacon
Ck<hex>: set encryptionkey pm: preset funk for mesh
Ct<hex>: set txmac pM: preset funk for pubMesh
Cc<hex>: set channel pr: preset funk for rem0te
Ct<hex>: set rxmac(0)
Cl<hex>: set rxlens t<char>: set packet dump type (b/B/m/M/0)
Ce<hex>: sec encrpytion on/off f<char><hex>: set filter stuff
ck<hex>: set encryptionkey
cm<hex>: set rxmac(0)
ct<hex>: set txmac
cc<hex>: set channel
cl<hex>: set rxlen
ce<hex>: sec encrpytion on/off
s <hex>: send packet s <hex>: send packet
s+ <hex>: send packet 10 times s+ <hex>: send packet 10 times
@ -13,4 +20,4 @@ sd <hex>: send packet with debugoutput
r: recv packets r: recv packets
r+<hex>: recv packets for <hex> seconds r+<hex>: recv packets for <hex> seconds
r-<hex>: recv <hex> packets (5 seconds max) r-<hex>: recv <hex> packets

View file

@ -0,0 +1,20 @@
#include <sysinit.h>
#include "basic/basic.h"
#include "basic/config.h"
#include <string.h>
/**************************************************************************/
#include "serial.gen"
void main_serial(void) {
GLOBAL(daytrig)=10;
GLOBAL(lcdbacklight)=10;
handleMenu(&mainmenu);
gpioSetValue (RB_LED3, 1);
ISPandReset();
};
void serial(void);

View file

@ -23,7 +23,7 @@
#define BEACON_CHANNEL 81 #define BEACON_CHANNEL 81
#define BEACON_MAC "\x1\x2\x3\x2\1" #define BEACON_MAC "\x1\x2\x3\x2\1"
#include "SECRETS" #include "SECRETS.release"
char funkencrypt=0; char funkencrypt=0;
@ -47,9 +47,15 @@ struct NRF_CFG config = {
.maclen ="\x10", .maclen ="\x10",
}; };
int process(char * input); char type=0;
char filter=0;
uint8_t filterdata[10];
char outc[2]= {0,0};
static int process(char * input);
#define INPUTLEN 99 #define INPUTLEN 99
//# MENU serial
void dwim(void){ void dwim(void){
char input[INPUTLEN+1]; char input[INPUTLEN+1];
int inputptr=0; int inputptr=0;
@ -58,6 +64,8 @@ void dwim(void){
usbCDCInit(); usbCDCInit();
delayms(500); delayms(500);
getInputWaitRelease(); getInputWaitRelease();
nrf_init();
gpioSetValue (RB_LED1, 0);
puts("D start\r\n"); puts("D start\r\n");
while(!getInputRaw()){ while(!getInputRaw()){
@ -97,13 +105,13 @@ void dwim(void){
}; };
inputptr+=l; inputptr+=l;
}; };
gpioSetValue (RB_LED1, 0);
puts("D exit\r\n"); puts("D exit\r\n");
} }
#define BUFLEN 32 #define BUFLEN 32
#define NYB(x) ((x>'9')?(x|0x20)-'a'+10:x-'0') #define NYB(x) ((x>'9')?(x|0x20)-'a'+10:x-'0')
uint8_t * hextobyte(char * input, int *len){ static uint8_t * hextobyte(char * input, int *len){
static uint8_t buf[BUFLEN]; static uint8_t buf[BUFLEN];
int p=0; int p=0;
@ -123,7 +131,16 @@ uint8_t * hextobyte(char * input, int *len){
return buf; return buf;
}; };
int process(char * input){ static uint32_t gethexval(char * input){
int len;
uint8_t *hex=hextobyte(input,&len);
uint32_t v=hex[0];
while(--len>0)
v=v*256+(*++hex);
return v;
};
static int process(char * input){
if(input == NULL || input[0]==0) if(input == NULL || input[0]==0)
return -1; return -1;
@ -135,7 +152,8 @@ int process(char * input){
if(input[0]=='i'){ if(input[0]=='i'){
nrf_init(); nrf_init();
nrf_config_set(&config); nrf_config_set(&config);
}else if(input[0]=='c'){ }else if(input[0]=='p'){
type=input[1];
if(input[1]=='m'){ if(input[1]=='m'){
config.channel=MESH_CHANNEL; config.channel=MESH_CHANNEL;
memcpy(config.txmac,MESH_MAC,5); memcpy(config.txmac,MESH_MAC,5);
@ -145,6 +163,18 @@ int process(char * input){
nrf_config_set(&config); nrf_config_set(&config);
memcpy(thekey,meshkey,sizeof(thekey)); memcpy(thekey,meshkey,sizeof(thekey));
funkencrypt=1; funkencrypt=1;
}else if(input[1]=='M'){
config.channel=83;
memcpy(config.txmac,MESH_MAC,5);
memcpy(config.mac0,MESH_MAC,5);
config.maclen[0]=0x20;
config.nrmacs=1;
nrf_config_set(&config);
static const uint32_t const pubmesh[4] = {
0x00000042, 0x000005ec, 0x00000023, 0x00000005
};
memcpy(thekey,pubmesh,sizeof(thekey));
funkencrypt=1;
}else if(input[1]=='r'){ }else if(input[1]=='r'){
config.channel=REMOTE_CHANNEL; config.channel=REMOTE_CHANNEL;
memcpy(config.txmac,REMOTE_MAC,5); memcpy(config.txmac,REMOTE_MAC,5);
@ -163,6 +193,43 @@ int process(char * input){
nrf_config_set(&config); nrf_config_set(&config);
memcpy(thekey,openbeaconkey,sizeof(thekey)); memcpy(thekey,openbeaconkey,sizeof(thekey));
funkencrypt=1; funkencrypt=1;
}else if(input[1]=='B'){
config.channel=BEACON_CHANNEL;
memcpy(config.txmac,BEACON_MAC,5);
memcpy(config.mac0,BEACON_MAC,5);
config.maclen[0]=0x10;
config.nrmacs=1;
nrf_config_set(&config);
static const uint32_t pubbeaconkey[4] = {
0xB4595344, 0xD3E119B6, 0xA814D0EC, 0xEFF5A24E
};
memcpy(thekey,pubbeaconkey,sizeof(thekey));
funkencrypt=1;
};
}else if(input[0]=='t'){
type=input[1];
}else if(input[0]=='c'){
int len;
uint8_t *hex=hextobyte(&input[2],&len);
if(input[1]=='k'){
thekey[0]=uint8ptouint32(hex);
thekey[1]=uint8ptouint32(hex+4);
thekey[2]=uint8ptouint32(hex+8);
thekey[3]=uint8ptouint32(hex+12);
}else if(input[1]=='m'){
memcpy(config.mac0,hex,5);
nrf_config_set(&config);
}else if(input[1]=='t'){
memcpy(config.txmac,hex,5);
nrf_config_set(&config);
}else if(input[1]=='c'){
config.channel=hex[0];
nrf_config_set(&config);
}else if(input[1]=='l'){
config.maclen[0]=hex[0];
nrf_config_set(&config);
}else if(input[1]=='e'){
funkencrypt= hex[0];
}else if(input[1]=='?'){ }else if(input[1]=='?'){
nrf_config_get(&config); nrf_config_get(&config);
puts_plus("Ch: ");puts_plus(IntToStrX( config.channel,2 )); puts_plus("\r\n"); puts_plus("Ch: ");puts_plus(IntToStrX( config.channel,2 )); puts_plus("\r\n");
@ -203,41 +270,6 @@ int process(char * input){
puts_plus(IntToStrX( funkencrypt,2 )); puts_plus(IntToStrX( funkencrypt,2 ));
puts_plus("\r\n"); puts_plus("\r\n");
}; };
}else if(input[0]=='C'){
int len;
uint8_t *hex=hextobyte(&input[2],&len);
if(input[1]=='k'){
thekey[0]=uint8ptouint32(hex);
thekey[1]=uint8ptouint32(hex+4);
thekey[2]=uint8ptouint32(hex+8);
thekey[3]=uint8ptouint32(hex+12);
}else if(input[1]=='m'){
config.mac0[0]=uint8ptouint32(hex);
config.mac0[1]=uint8ptouint32(hex+4);
config.mac0[2]=uint8ptouint32(hex+8);
config.mac0[3]=uint8ptouint32(hex+12);
config.mac0[4]=uint8ptouint32(hex+16);
nrf_config_set(&config);
}else if(input[1]=='t'){
config.txmac[0]=uint8ptouint32(hex);
config.txmac[1]=uint8ptouint32(hex+4);
config.txmac[2]=uint8ptouint32(hex+8);
config.txmac[3]=uint8ptouint32(hex+12);
config.txmac[4]=uint8ptouint32(hex+16);
nrf_config_set(&config);
}else if(input[1]=='c'){
config.channel=*hex;
nrf_config_set(&config);
}else if(input[1]=='l'){
config.maclen[0]=uint8ptouint32(hex);
config.maclen[1]=uint8ptouint32(hex+4);
config.maclen[2]=uint8ptouint32(hex+8);
config.maclen[3]=uint8ptouint32(hex+12);
config.maclen[4]=uint8ptouint32(hex+16);
nrf_config_set(&config);
}else if(input[1]=='e'){
funkencrypt= uint8ptouint32(hex);
};
}else if (input[0]=='s'){ }else if (input[0]=='s'){
__attribute__ ((aligned (4))) uint8_t buf[32]; __attribute__ ((aligned (4))) uint8_t buf[32];
int status=0; int status=0;
@ -262,14 +294,18 @@ int process(char * input){
memcpy(buf,hex,len); memcpy(buf,hex,len);
status=nrf_snd_pkt_crc_encr(len,buf,funkencrypt?thekey:NULL); status=nrf_snd_pkt_crc_encr(len,buf,funkencrypt?thekey:NULL);
puts_plus("P ");
puts_plus("[");puts_plus(IntToStrX(len,2));puts_plus("] ");
if(debug){ if(debug){
puts_plus("P ");
puts_plus("[");puts_plus(IntToStrX(len,2));puts_plus("] ");
for(int i=0;i<len;i++){ for(int i=0;i<len;i++){
puts_plus(IntToStrX( buf[i],2 )); puts_plus(IntToStrX( buf[i],2 ));
puts_plus(" "); puts_plus(" ");
}; };
}; };
puts_plus("S ");
puts_plus("[");puts_plus(IntToStrX(len,2));puts_plus("] ");
puts_plus("state=");
puts_plus(IntToStrX( status,2 ));
puts("\r\n"); puts("\r\n");
while(--ctr>0){ while(--ctr>0){
@ -277,46 +313,60 @@ int process(char * input){
memcpy(buf,hex,len); memcpy(buf,hex,len);
status=nrf_snd_pkt_crc_encr(len,buf,funkencrypt?thekey:NULL); status=nrf_snd_pkt_crc_encr(len,buf,funkencrypt?thekey:NULL);
}; };
}else if (input[1]=='t'){
static int ctr=1;
int status;
buf[0]=0x10; // Length: 16 bytes
buf[1]='1'; // Proto
buf[2]=0x00;
buf[3]=0x00; // Unused
uint32touint8p(ctr++,buf+4);
uint32touint8p(0x5ec,buf+8);
buf[12]=0xff; // salt (0xffff always?)
buf[13]=0xff;
status=nrf_snd_pkt_crc_encr(16,buf,funkencrypt?thekey:NULL);
}else{ }else{
;
};
puts_plus("\r\n");
}else if (input[0]=='f'){
int len;
filter=input[1];
uint8_t *hex=hextobyte(input+2,&len);
if(len>9)
len=9;
memcpy(filterdata,hex,len);
puts_plus("F ");
if(filter){
puts_plus("[");
outc[0]=filter;
puts_plus(outc);
puts_plus("]");
for(int i=0;i<len;i++){
puts_plus(IntToStrX(filterdata[i],2 ));
};
}else{
puts_plus("off");
}; };
puts_plus("S state=");
puts_plus(IntToStrX( status,2 ));
puts_plus("\r\n"); puts_plus("\r\n");
}else if (input[0]=='r'){ }else if (input[0]=='r'){
__attribute__ ((aligned (4))) uint8_t buf[32]; __attribute__ ((aligned (4))) uint8_t buf[32];
int len; int len;
int pctr=5; int pctr=5;
int t=getTimer()+5000/SYSTICKSPEED; int t=5;
if(input[1]=='+'){ if(input[1]=='+'){
if(input[2]!=0){ if(input[2]!=0){
uint8_t *hex=hextobyte(&input[2],&len); t=gethexval(&input[2]);
t=getTimer()+hex[0]*1000/SYSTICKSPEED;
}; };
pctr=-1; pctr=-1;
} }
if(input[1]=='-'){ if(input[1]=='-'){
uint8_t *hex=hextobyte(&input[2],&len); pctr=gethexval(&input[2]);
pctr=hex[0]; t=-1;
} }
puts_plus("D receive ...\r\n"); puts_plus("D rcv: ");
puts_plus(IntToStr(pctr,8,0));
puts_plus("pkts, ");
puts_plus(IntToStr(t,8,0));
puts_plus("secs ");
if(filter){
puts_plus("FILTER=");
outc[0]=filter;
puts_plus(outc);
};
puts_plus(" ...\r\n");
if(t>0)
t=getTimer()+t*1000/SYSTICKSPEED;
nrf_rcv_pkt_start(); nrf_rcv_pkt_start();
do{ do{
len=nrf_rcv_pkt_poll_dec(sizeof(buf),buf,funkencrypt?thekey:NULL); len=nrf_rcv_pkt_poll_dec(sizeof(buf),buf,funkencrypt?thekey:NULL);
@ -325,17 +375,76 @@ int process(char * input){
delayms(10); delayms(10);
continue; continue;
}; };
puts_plus("R "); if (!filter){
puts_plus("[");puts_plus(IntToStrX(len,2));puts_plus("] "); if(len==-3){
if(len==-3){ puts_plus("[!crc] ");
puts_plus("[!crc] "); len=32;
len=16; };
}; };
for(int i=0;i<len;i++){ if(type=='m' || type=='M'){
puts_plus(IntToStrX( buf[i],2 )); if(filter && filter!=buf[0])
continue;
puts_plus("R ");
puts_plus(IntToStrX( buf[0],2 ));
puts_plus(" "); puts_plus(" ");
puts_plus(IntToStrX( buf[1],2 ));
puts_plus(" ");
puts_plus(IntToStrX( uint8ptouint32(buf+2),8 ));
puts_plus(" ");
puts_plus(IntToStrX( uint8ptouint32(buf+6),8 ));
puts_plus(" ");
puts_plus(IntToStrX( uint8ptouint32(buf+10),8 ));
puts_plus(" ");
puts_plus(IntToStrX( uint8ptouint32(buf+14),8 ));
puts_plus(" ");
puts_plus(IntToStrX( uint8ptouint32(buf+18),8 ));
puts_plus(" ");
puts_plus(IntToStrX( uint8ptouint32(buf+22),8 ));
puts_plus(" ");
puts_plus(IntToStrX( uint8ptouint32(buf+26),8 ));
puts_plus(" ");
puts_plus(IntToStrX( buf[30],2 ));
puts_plus(IntToStrX( buf[31],2 ));
puts_plus(" ");
}else if(type=='B'){
if(filter)
if(uint8ptouint32(buf+8)!=uint8ptouint32(filterdata))
continue;
puts_plus("RF ");
puts_plus(IntToStrX( buf[2],2 ));
puts_plus(" ");
puts_plus(IntToStrX( uint8ptouint32(buf+8),8 ));
}else if(type=='b'){
if(filter)
if(uint8ptouint32(buf+8)!=uint8ptouint32(filterdata))
continue;
puts_plus("R ");
puts_plus(IntToStrX( buf[0],2 ));
puts_plus(" ");
puts_plus(IntToStrX( buf[1],2 ));
puts_plus(" ");
puts_plus(IntToStrX( buf[2],2 ));
puts_plus(" ");
puts_plus(IntToStrX( buf[3],2 ));
puts_plus(" ");
puts_plus(IntToStrX( uint8ptouint32(buf+4),8 ));
puts_plus(" ");
puts_plus(IntToStrX( uint8ptouint32(buf+8),8 ));
puts_plus(" ");
puts_plus(IntToStrX( buf[12],2 ));
puts_plus(IntToStrX( buf[13],2 ));
puts_plus(" ");
puts_plus(IntToStrX( buf[14],2 ));
puts_plus(IntToStrX( buf[15],2 ));
}else{
puts_plus("R ");
puts_plus("[");puts_plus(IntToStrX(len,2));puts_plus("] ");
for(int i=0;i<len;i++){
puts_plus(IntToStrX( buf[i],2 ));
puts_plus(" ");
};
}; };
if(pctr<0){ if(1){
int l=0; int l=0;
CDC_OutBufAvailChar (&l); CDC_OutBufAvailChar (&l);
if(l>0){ if(l>0){
@ -344,9 +453,9 @@ int process(char * input){
}; };
}; };
puts("\r\n"); puts("\r\n");
if(pctr--==0) if(--pctr==0)
break; break;
}while(t>getTimer()); }while((t>0)?(t>getTimer()):1);
nrf_rcv_pkt_end(); nrf_rcv_pkt_end();
}else{ }else{

View file

@ -0,0 +1,49 @@
#include <sysinit.h>
#include "basic/basic.h"
#include "lcd/print.h"
#include <string.h>
#include "core/cpu/cpu.h"
#include "core/uart/uart.h"
/**************************************************************************/
#define BUF 5
void main_uart(void) {
uint8_t uartBuffer[BUF] = { 'T', 'e', 's', 't', '\n' };
uint8_t o[2]={0,0};
gpioSetDir(RB_LED0, gpioDirection_Output);
gpioSetValue (RB_LED0, 1);
lcdPrintln("Hi");
lcdRefresh();
uartInit(9600);
lcdPrintln("Inited.");
lcdRefresh();
uartSend((uint8_t *)uartBuffer, BUF);
lcdPrintln("sent.");
lcdRefresh();
uartRxBufferWrite('x');
// Get a reference to the UART control block
// uart_pcb_t *pcb = uartGetPCB();
gpioSetValue (RB_LED0, 1-gpioGetValue(RB_LED0));
// Read any text available in the queue
while (uartRxBufferDataPending())
{
gpioSetValue (RB_LED0, 1-gpioGetValue(RB_LED0));
// Read the first available character
uint8_t c = uartRxBufferRead();
o[0]=c;
lcdPrint(o);
lcdRefresh();
uartSend(&c, 1);
}
};

View file

@ -82,3 +82,9 @@
#define CFG_USBCDC_BUFFERSIZE (256) #define CFG_USBCDC_BUFFERSIZE (256)
/* you will need these for the UART */
#if 0
#define CFG_INTERFACE_UART (1)
#define CFG_UART_BAUDRATE (115200)
#define CFG_UART_BUFSIZE (512)
#endif

View file

@ -0,0 +1,50 @@
#include <sysinit.h>
#include <string.h>
#include "basic/basic.h"
#include "basic/config.h"
#include "lcd/render.h"
#include "lcd/print.h"
#include "usetable.h"
/**************************************************************************/
void ram(void) {
int v,mv;
do{
lcdClear();
lcdPrintln("Battery status:");
mv=GetVoltage();
v=mv/1000;
lcdNl();
if (mv<3550){
lcdPrintln(" Charge NOW!");
}else if (mv<3650){
lcdPrintln(" Charge soon");
}else if (mv<4000){
lcdPrintln(" OK");
}else if(mv<4200){
lcdPrintln(" Good");
}else{
lcdPrintln(" Full");
};
lcdNl();
lcdPrint(" ");
lcdPrint(IntToStr(v,2,0));
lcdPrint(".");
lcdPrint(IntToStr(mv%1000,3,F_ZEROS));
lcdPrintln("V");
lcdNl();
if(gpioGetValue(RB_PWR_CHRG)){
lcdPrintln("(not charging)");
}else{
lcdPrintln("CHARGING");
};
lcdRefresh();
} while ((getInputWaitTimeout(242))==BTN_NONE);
}

View file

@ -1,4 +1,8 @@
drive=/cygdrive/f drive=/cygdrive/f
if [ ! -z "$1" ] ; then
dirve=/cygdrive/$a
fi
file=$drive/firmware.bin file=$drive/firmware.bin
while : ; do while : ; do