235 lines
5.6 KiB
C
235 lines
5.6 KiB
C
#include <sysinit.h>
|
|
|
|
#include "basic/basic.h"
|
|
|
|
#include "lcd/render.h"
|
|
#include "lcd/backlight.h"
|
|
#include "lcd/allfonts.h"
|
|
|
|
#include "funk/nrf24l01p.h"
|
|
|
|
/**************************************************************************/
|
|
|
|
void f_init(void){
|
|
nrf_init();
|
|
};
|
|
|
|
#define CS_LOW() gpioSetValue(RB_SPI_NRF_CS, 0)
|
|
#define CS_HIGH() gpioSetValue(RB_SPI_NRF_CS, 1)
|
|
#include "core/ssp/ssp.h"
|
|
|
|
void f_status(void){
|
|
int dx=0;
|
|
int dy=8;
|
|
uint8_t buf[4];
|
|
|
|
// Enable SPI correctly
|
|
sspInit(0, sspClockPolarity_Low, sspClockPhase_RisingEdge);
|
|
|
|
// Enable CS & CE pins
|
|
gpioSetDir(RB_SPI_NRF_CS, gpioDirection_Output);
|
|
gpioSetPullup(&RB_SPI_NRF_CS_IO, gpioPullupMode_Inactive);
|
|
|
|
gpioSetDir(RB_NRF_CE, gpioDirection_Output);
|
|
gpioSetPullup(&RB_NRF_CE_IO, gpioPullupMode_Inactive);
|
|
gpioSetValue(RB_NRF_CE, 0);
|
|
|
|
delayms(10);
|
|
|
|
buf[0]=C_W_REGISTER | R_CONFIG;
|
|
buf[1]=R_CONFIG_PRIM_RX| R_CONFIG_PWR_UP| R_CONFIG_CRCO;
|
|
// buf[0]=C_R_REGISTER | 5; buf[1]=10;
|
|
// buf[0]=C_W_REGISTER | R_EN_AA; buf[1]=0x21;
|
|
buf[2]=0;
|
|
buf[3]=0;
|
|
|
|
dx=DoString(0,dy,"Snd:"); DoIntX(dx,dy,*(int*)buf);dy+=8;
|
|
|
|
CS_LOW();
|
|
delayms(10);
|
|
sspSend(0, buf, 2);
|
|
sspReceive(0, buf, 2);
|
|
CS_HIGH();
|
|
delayms(10);
|
|
|
|
dx=DoString(0,dy,"Rcv:"); DoIntX(dx,dy,*(int*)buf);dy+=8;
|
|
|
|
/*
|
|
CS_LOW();
|
|
status=nrf_cmd_status(C_NOP);
|
|
CS_HIGH();
|
|
dx=DoString(0,dy,"St:"); DoIntX(dx,dy,status); dy+=8;
|
|
*/
|
|
|
|
buf[0]=C_R_REGISTER | R_CONFIG;
|
|
// buf[0]=C_R_REGISTER | R_EN_AA;
|
|
buf[1]=0;
|
|
buf[2]=0;
|
|
buf[3]=0;
|
|
dx=DoString(0,dy,"S2:"); DoIntX(dx,dy,*(int*)buf);dy+=8;
|
|
|
|
CS_LOW();
|
|
delayms(10);
|
|
sspSend(0, buf, 2);
|
|
sspReceive(0, buf, 2);
|
|
CS_HIGH();
|
|
delayms(10);
|
|
|
|
dx=DoString(0,dy,"R2:"); DoIntX(dx,dy,*(int*)buf);dy+=8;
|
|
};
|
|
|
|
void f_recv(void){
|
|
};
|
|
|
|
void gotoISP(void) {
|
|
DoString(0,0,"Enter ISP!");
|
|
lcdDisplay(0);
|
|
ISPandReset(5);
|
|
}
|
|
|
|
/**************************************************************************/
|
|
|
|
struct MENU_DEF {
|
|
char *text;
|
|
void (*callback)(void);
|
|
};
|
|
|
|
typedef const struct MENU_DEF * menuentry;
|
|
|
|
struct MENU {
|
|
char *title;
|
|
menuentry *entries;
|
|
};
|
|
|
|
const struct MENU_DEF menu_ISP = {"Invoke ISP", &gotoISP};
|
|
const struct MENU_DEF menu_init = {"F Init", &f_init};
|
|
const struct MENU_DEF menu_status = {"F Status", &f_status};
|
|
const struct MENU_DEF menu_rcv = {"F Recv", &f_recv};
|
|
const struct MENU_DEF menu_nop = {"---", NULL};
|
|
|
|
static menuentry menu[] = {
|
|
&menu_status,
|
|
&menu_init,
|
|
&menu_rcv,
|
|
&menu_nop,
|
|
&menu_ISP,
|
|
NULL,
|
|
};
|
|
|
|
static const struct MENU mainmenu = {"Mainmenu", menu};
|
|
|
|
void handleMenu(const struct MENU *the_menu) ;
|
|
|
|
void main_funk(void) {
|
|
|
|
backlightInit();
|
|
|
|
while (1) {
|
|
lcdFill(0); // clear display buffer
|
|
lcdDisplay(0);
|
|
handleMenu(&mainmenu);
|
|
gotoISP();
|
|
}
|
|
|
|
return;
|
|
}
|
|
|
|
void handleMenu(const struct MENU *the_menu) {
|
|
uint8_t back = 0;
|
|
int8_t menuselection = 0;
|
|
uint8_t numentries = 0;
|
|
uint8_t visible_lines = 0;
|
|
uint8_t current_offset = 0;
|
|
|
|
if (the_menu == NULL) return;
|
|
|
|
font = &Font_7x8;
|
|
|
|
for (numentries = 0; the_menu->entries[numentries] != NULL; numentries++);
|
|
|
|
visible_lines = RESY/font->u8Height;
|
|
|
|
if (visible_lines < 2) return;
|
|
|
|
visible_lines--; // subtract title line
|
|
|
|
while (!back) {
|
|
uint8_t line = 0;
|
|
|
|
lcdFill(0); // clear display buffer
|
|
|
|
DoString(0, line, the_menu->title);
|
|
line += font->u8Height;
|
|
|
|
for (uint8_t i = current_offset; i < (visible_lines + current_offset) && i < numentries; i++) {
|
|
DoString(14, line, the_menu->entries[i]->text);
|
|
if (i == menuselection) {
|
|
DoString(0, line, "* ");
|
|
}
|
|
line += font->u8Height;
|
|
}
|
|
|
|
lcdDisplay(0);
|
|
|
|
switch (getInput()) {
|
|
case BTN_UP:
|
|
menuselection--;
|
|
if (menuselection < current_offset) {
|
|
if (menuselection < 0) {
|
|
menuselection = numentries-1;
|
|
current_offset = ((numentries-1)/visible_lines) * visible_lines;
|
|
} else {
|
|
current_offset -= visible_lines;
|
|
}
|
|
}
|
|
break;
|
|
case BTN_DOWN:
|
|
menuselection++;
|
|
if (menuselection > (current_offset + visible_lines-1) || menuselection >= numentries) {
|
|
if (menuselection >= numentries) {
|
|
menuselection = 0;
|
|
current_offset = 0;
|
|
} else {
|
|
current_offset += visible_lines;
|
|
}
|
|
}
|
|
break;
|
|
case BTN_LEFT:
|
|
return;
|
|
case BTN_RIGHT:
|
|
if (the_menu->entries[menuselection]->callback!=NULL)
|
|
the_menu->entries[menuselection]->callback();
|
|
while (getInput()==BTN_NONE) delayms(10);
|
|
break;
|
|
case BTN_ENTER:
|
|
lcdFill(0);
|
|
DoString(0,0,"Called....");
|
|
lcdDisplay(0);
|
|
if (the_menu->entries[menuselection]->callback!=NULL)
|
|
the_menu->entries[menuselection]->callback();
|
|
lcdDisplay(0);
|
|
while (getInput()==BTN_NONE) delayms(10);
|
|
|
|
break;
|
|
default:
|
|
/* no button pressed */
|
|
break;
|
|
}
|
|
|
|
}
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
void tick_funk(void){
|
|
static int foo=0;
|
|
static int toggle=0;
|
|
if(foo++>50){
|
|
toggle=1-toggle;
|
|
foo=0;
|
|
gpioSetValue (RB_LED0, toggle);
|
|
};
|
|
return;
|
|
};
|
|
|