1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00

* some work on rx handling in cc110x_ng

* added first version of cc110x_ng test application
* introduced a generic transceiver interface and module
This commit is contained in:
Oliver Hahm 2010-11-19 20:10:09 +01:00
parent 2b498020b1
commit 044616bf19
7 changed files with 173 additions and 0 deletions

View File

@ -0,0 +1,5 @@
SubDir TOP projects test_cc110x_ng ;
Module test_cc110x_ng : main.c : cc110x_ng shell ps rtc posix_io uart0 ;
UseModule test_cc110x_ng ;

View File

@ -0,0 +1,28 @@
#include <shell.h>
#include <board_uart0.h>
#include <posix_io.h>
#include <thread.h>
#include <board.h>
#include <hwtimer.h>
#define SHELL_STACK_SIZE (4096)
char shell_stack_buffer[SHELL_STACK_SIZE];
shell_t shell;
const shell_command_t sc[] = {{NULL, NULL, NULL}};
void shell_runner(void) {
shell_init(&shell, sc, uart0_readc, uart0_putc);
posix_open(uart0_handler_pid, 0);
shell_run(&shell);
}
int main(void) {
thread_create(shell_stack_buffer, SHELL_STACK_SIZE, PRIORITY_MAIN-1, CREATE_STACKTEST, shell_runner, "shell");
while (1) {
LED_GREEN_TOGGLE;
hwtimer_wait(1000 * 1000);
}
}

View File

@ -0,0 +1,13 @@
#!/usr/bin/expect
set timeout 5
spawn pseudoterm $env(PORT)
expect {
"Hello World!" {}
timeout { exit 1 }
}
puts "\nTest successful!\n"

View File

@ -35,6 +35,8 @@ Module auto_init : auto_init.c ;
Module chardev_thread : chardev_thread.c : ringbuffer ; Module chardev_thread : chardev_thread.c : ringbuffer ;
Module uart0 : uart0.c : ringbuffer chardev_thread ; Module uart0 : uart0.c : ringbuffer chardev_thread ;
Module transceiver : transceiver.c ;
SubInclude TOP sys net ; SubInclude TOP sys net ;
SubInclude TOP sys lib ; SubInclude TOP sys lib ;
SubInclude TOP sys shell ; SubInclude TOP sys shell ;

View File

@ -73,6 +73,25 @@ typedef struct __attribute__ ((packed)) packet_info_t
bool promiscuous; ///< Radio layer: whether network interface is in promiscuous mode bool promiscuous; ///< Radio layer: whether network interface is in promiscuous mode
} packet_info_t; } packet_info_t;
typedef struct __attribute__ ((packed)) {
uint8_t rssi; ///< Radio layer: RSSI
uint8_t lqi; ///< Radio layer: LQI
} radio_info_t;
/**
* @brief General link layer packet format
*/
typedef struct __attribute__ ((packed)) {
uint16_t src; ///< Radio source address
uint16_t dst; ///< Radio destination address
uint8_t rssi; ///< Radio Signal Strength Indication
uint8_t lqi; ///< Link Quality Indicator
uint8_t length; ///< Length of payload
uint8_t *data; ///< Payload
} radio_packet_t;
/** /**
* Packet handler (receive function) of all layers. * Packet handler (receive function) of all layers.
* @param [in/out] payload Pointer to packet payload data * @param [in/out] payload Pointer to packet payload data

28
sys/include/transceiver.h Normal file
View File

@ -0,0 +1,28 @@
#ifndef TRANSCEIVER_H
#define TRANSCEIVER_H
#define TRANSCEIVER_BUFFER_SIZE (10)
#define TRANSCEIVER_STACK_SIZE (4096)
enum transceiver_msg_type_t {
RCV_PKT,
SND_PKT,
SND_ACK,
SWITCH_RX,
POWERDOWN,
};
enum transceiver_type_t {
NONE,
CC1100,
CC1020
};
void transceiver_init(transceiver_type_t transceiver);
void transceiver_start(void);
extern int transceiver_pid;
extern void *transceiver_rx_buffer;
#endif /* TRANSCEIVER_H */

78
sys/transceiver.c Normal file
View File

@ -0,0 +1,78 @@
#include <stdio.h>
#include <errno.h>
#include <transceiver.h>
/* supported transceivers */
#include <cc1100.h>
transceiver_type_t transceiver = NONE;
int transceiver_pid = EINVAL;
radio_packet_t transceiver_buffer[TRANSCEIVER_BUFFER_SIZE];
static volatile uint8_t rx_buffer_pos = 0;
static volatile uint8_t transceiver_buffer_pos = 0;
const char transceiver_stack[TRANSCEIVER_STACK_SIZE];
void run(void);
void receive_packet(void);
void transceiver_init(transceiver_type_t t) {
switch (t) {
case CC110:
transceiver = t;
cc1100_init();
break;
default:
puts("Invalid transceiver type");
break;
}
}
void transceiver_start(void) {
transceiver_pid = thread_create(transceiver_stack, TRANSCEIVER_STACK_SIZE, PRIORITY_MAIN-1, CREATE_STACKTEST | CREATE_SLEEPING, run, "Transceiver");
if (transceiver < 0) {
puts("Error creating transceiver thread");
}
}
void run(void) {
msg m;
while (1) {
msg_receive(&m);
switch (m) {
case RCV_PKT:
receive_packet();
break;
default:
DEBUG("Unknown message received\n");
break;
}
}
}
void receive_packet(void) {
switch (transveiver) {
case CC1100:
dINT();
rx_buffer_pos = cc1100_rx_buffer_next - 1;
cc1100_packet_t p = cc1100_rx_buffer[rx_buffer_pos].packet;
radio_info_t info = cc1100_rx_buffer[rx_buffer_pos].info;
radio_packet_t trans_p = transceiver_buffer[transceiver_buffer_pos];
trans_p.src = p.phy_src;
trans_p.dst = p.address;
trans_p.rssi = info.rssi;
trans_p.lqi = info.lqi;
trans_p.length = p.length;
/* TODO: copy payload */
eINT();
break;
default:
puts("Invalid transceiver type");
break;
}
}