Contiki 2.5
|
HAL function names have the following conventions: More...
Files | |
file | hal.c |
This file contains low-level radio driver code. | |
file | hal.h |
This file contains low-level radio driver code. | |
file | hal.h |
This file contains low-level radio driver code. | |
file | halbb.c |
This file contains low-level radio driver code. | |
Data Structures | |
struct | hal_rx_frame_t |
This struct defines the rx data container. More... | |
Macros | |
#define | HAL_DUMMY_READ (0x00) |
Dummy value for the SPI. More... | |
#define | HAL_TRX_CMD_RW (0xC0) |
Register Write (short mode). More... | |
#define | HAL_TRX_CMD_RR (0x80) |
Register Read (short mode). More... | |
#define | HAL_TRX_CMD_FW (0x60) |
Frame Transmit Mode (long mode). More... | |
#define | HAL_TRX_CMD_FR (0x20) |
Frame Receive Mode (long mode). More... | |
#define | HAL_TRX_CMD_SW (0x40) |
SRAM Write. More... | |
#define | HAL_TRX_CMD_SR (0x00) |
SRAM Read. More... | |
#define | HAL_TRX_CMD_RADDRM (0x7F) |
Register Address Mask. More... | |
#define | HAL_CALCULATED_CRC_OK (0) |
CRC calculated over the frame including the CRC field should be 0. More... | |
#define | HAL_SS_HIGH() (HAL_PORT_SPI |= ( 1 << HAL_SS_PIN )) |
MACRO for pulling SS high. More... | |
#define | HAL_SS_LOW() (HAL_PORT_SPI &= ~( 1 << HAL_SS_PIN )) |
MACRO for pulling SS low. More... | |
#define | RADIO_VECT TIMER1_CAPT_vect |
Macros defined for HAL_TIMER1. More... | |
#define | AVR_ENTER_CRITICAL_REGION() {uint8_t volatile saved_sreg = SREG; cli( ) |
This macro will protect the following code from interrupts. More... | |
#define | AVR_LEAVE_CRITICAL_REGION() SREG = saved_sreg;} |
This macro must always be used in conjunction with AVR_ENTER_CRITICAL_REGION so that interrupts are enabled again. More... | |
#define | hal_enable_trx_interrupt() HAL_ENABLE_RADIO_INTERRUPT( ) |
Enable the interrupt from the radio transceiver. | |
#define | hal_disable_trx_interrupt() HAL_DISABLE_RADIO_INTERRUPT( ) |
Disable the interrupt from the radio transceiver. More... | |
#define | HAL_SS_HIGH() (HAL_PORT_SS |= ( 1 << HAL_SS_PIN )) |
MACRO for pulling SS high. More... | |
#define | HAL_SS_LOW() (HAL_PORT_SS &= ~( 1 << HAL_SS_PIN )) |
MACRO for pulling SS low. More... | |
#define | HAL_ENABLE_RADIO_INTERRUPT() ( INT1IC.BYTE |= 1 ) |
Macros defined for HAL_TIMER1. More... | |
#define | HAL_ENTER_CRITICAL_REGION() MULLE_ENTER_CRITICAL_REGION( ) |
This macro will protect the following code from interrupts. More... | |
#define | HAL_LEAVE_CRITICAL_REGION() MULLE_LEAVE_CRITICAL_REGION( ) |
This macro must always be used in conjunction with HAL_ENTER_CRITICAL_REGION so that interrupts are enabled again. More... | |
#define | hal_enable_trx_interrupt() HAL_ENABLE_RADIO_INTERRUPT( ) |
Enable the interrupt from the radio transceiver. | |
#define | hal_disable_trx_interrupt() HAL_DISABLE_RADIO_INTERRUPT( ) |
Disable the interrupt from the radio transceiver. More... | |
#define | HAL_SPI_TRANSFER_OPEN() |
This function is called when a rx_start interrupt is signaled. More... | |
#define | HAL_RF230_ISR() M16C_INTERRUPT(M16C_INT1) |
This function initializes the Hardware Abstraction Layer. | |
Typedefs | |
typedef void(* | hal_rx_start_isr_event_handler_t )(uint32_t const isr_timestamp, uint8_t const frame_length) |
RX_START event handler callback type. More... | |
typedef void(* | hal_trx_end_isr_event_handler_t )(uint32_t const isr_timestamp) |
RRX_END event handler callback type. More... | |
typedef void(* | hal_rx_start_isr_event_handler_t )(uint32_t const isr_timestamp, uint8_t const frame_length) |
RX_START event handler callback type. More... | |
typedef void(* | hal_trx_end_isr_event_handler_t )(uint32_t const isr_timestamp) |
RRX_END event handler callback type. More... | |
Functions | |
void | hal_init (void) |
This function initializes the Hardware Abstraction Layer. | |
void | hal_reset_flags (void) |
This function reset the interrupt flags and interrupt event handlers (Callbacks) to their default value. | |
uint8_t | hal_get_bat_low_flag (void) |
This function returns the current value of the BAT_LOW flag. More... | |
void | hal_clear_bat_low_flag (void) |
This function clears the BAT_LOW flag. | |
hal_trx_end_isr_event_handler_t | hal_get_trx_end_event_handler (void) |
This function is used to set new TRX_END event handler, overriding old handler reference. | |
void | hal_set_trx_end_event_handler (hal_trx_end_isr_event_handler_t trx_end_callback_handle) |
This function is used to set new TRX_END event handler, overriding old handler reference. | |
void | hal_clear_trx_end_event_handler (void) |
Remove event handler reference. | |
hal_rx_start_isr_event_handler_t | hal_get_rx_start_event_handler (void) |
This function returns the active RX_START event handler. More... | |
void | hal_set_rx_start_event_handler (hal_rx_start_isr_event_handler_t rx_start_callback_handle) |
This function is used to set new RX_START event handler, overriding old handler reference. | |
void | hal_clear_rx_start_event_handler (void) |
Remove event handler reference. | |
uint8_t | hal_get_pll_lock_flag (void) |
This function returns the current value of the PLL_LOCK flag. More... | |
void | hal_clear_pll_lock_flag (void) |
This function clears the PLL_LOCK flag. | |
uint8_t | hal_register_read (uint8_t address) |
This function reads data from one of the radio transceiver's registers. More... | |
void | hal_register_write (uint8_t address, uint8_t value) |
This function writes a new value to one of the radio transceiver's registers. More... | |
uint8_t | hal_subregister_read (uint8_t address, uint8_t mask, uint8_t position) |
This function reads the value of a specific subregister. More... | |
void | hal_subregister_write (uint8_t address, uint8_t mask, uint8_t position, uint8_t value) |
This function writes a new value to one of the radio transceiver's subregisters. More... | |
void | hal_frame_read (hal_rx_frame_t *rx_frame, rx_callback_t rx_callback) |
This function will upload a frame from the radio transceiver's frame buffer. More... | |
void | hal_frame_write (uint8_t *write_buffer, uint8_t length) |
This function will download a frame to the radio transceiver's frame buffer. More... | |
void | hal_sram_read (uint8_t address, uint8_t length, uint8_t *data) |
Read SRAM. More... | |
void | hal_sram_write (uint8_t address, uint8_t length, uint8_t *data) |
Write SRAM. More... | |
void | RADIO_VECT (void) |
ISR for the radio IRQ line, triggered by the input capture. More... | |
void | TIMER1_OVF_vect (void) |
Timer Overflow ISR This is the interrupt service routine for timer1 overflow. | |
void | hal_frame_read (hal_rx_frame_t *rx_frame) |
This function will upload a frame from the radio transceiver's frame buffer. More... | |
This is the list of pin configurations needed for a given platform. | |
#define | RAVEN_D 4 |
#define | RAVENUSB_C 1 |
#define | RCB_B 2 |
#define | ZIGBIT 3 |
#define | IRIS 5 |
Pin macros | |
These macros convert the platform-specific pin defines into names and functions that the source code can directly use. | |
#define | SLP_TR SLPTRPIN |
Pin number that corresponds to the SLP_TR pin. More... | |
#define | DDR_SLP_TR DDR( SLPTRPORT ) |
Data Direction Register that corresponds to the port where SLP_TR is connected. More... | |
#define | PORT_SLP_TR PORT( SLPTRPORT ) |
Port (Write Access) where SLP_TR is connected. More... | |
#define | PIN_SLP_TR PIN( SLPTRPORT ) |
Pin (Read Access) where SLP_TR is connected. More... | |
#define | hal_set_slptr_high() ( PORT_SLP_TR |= ( 1 << SLP_TR ) ) |
This macro pulls the SLP_TR pin high. More... | |
#define | hal_set_slptr_low() ( PORT_SLP_TR &= ~( 1 << SLP_TR ) ) |
This macro pulls the SLP_TR pin low. More... | |
#define | hal_get_slptr() ( ( PIN_SLP_TR & ( 1 << SLP_TR ) ) >> SLP_TR ) |
Read current state of the SLP_TR pin (High/Low). More... | |
#define | RST RSTPIN |
Pin number that corresponds to the RST pin. More... | |
#define | DDR_RST DDR( RSTPORT ) |
Data Direction Register that corresponds to the port where RST is. | |
#define | PORT_RST PORT( RSTPORT ) |
Port (Write Access) where RST is connected. More... | |
#define | PIN_RST PIN( RSTPORT ) |
Pin (Read Access) where RST is connected. More... | |
#define | hal_set_rst_high() ( PORT_RST |= ( 1 << RST ) ) |
This macro pulls the RST pin high. More... | |
#define | hal_set_rst_low() ( PORT_RST &= ~( 1 << RST ) ) |
This macro pulls the RST pin low. More... | |
#define | hal_get_rst() ( ( PIN_RST & ( 1 << RST ) ) >> RST ) |
Read current state of the RST pin (High/Low). More... | |
#define | HAL_SS_PIN SSPIN |
The slave select pin. More... | |
#define | HAL_PORT_SPI PORT( SPIPORT ) |
The SPI module is located on PORTB. More... | |
#define | HAL_DDR_SPI DDR( SPIPORT ) |
Data Direction Register for PORTB. More... | |
#define | HAL_DD_SS SSPIN |
Data Direction bit for SS. More... | |
#define | HAL_DD_SCK SCKPIN |
Data Direction bit for SCK. More... | |
#define | HAL_DD_MOSI MOSIPIN |
Data Direction bit for MOSI. More... | |
#define | HAL_DD_MISO MISOPIN |
Data Direction bit for MISO. More... | |
Macros for radio operation. | |
#define | HAL_BAT_LOW_MASK ( 0x80 ) |
Mask for the BAT_LOW interrupt. More... | |
#define | HAL_TRX_UR_MASK ( 0x40 ) |
Mask for the TRX_UR interrupt. More... | |
#define | HAL_TRX_END_MASK ( 0x08 ) |
Mask for the TRX_END interrupt. More... | |
#define | HAL_RX_START_MASK ( 0x04 ) |
Mask for the RX_START interrupt. More... | |
#define | HAL_PLL_UNLOCK_MASK ( 0x02 ) |
Mask for the PLL_UNLOCK interrupt. More... | |
#define | HAL_PLL_LOCK_MASK ( 0x01 ) |
Mask for the PLL_LOCK interrupt. More... | |
#define | HAL_MIN_FRAME_LENGTH ( 0x03 ) |
A frame should be at least 3 bytes. More... | |
#define | HAL_MAX_FRAME_LENGTH ( 0x7F ) |
A frame should no more than 127 bytes. More... | |
Pin macros | |
These macros convert the platform-specific pin defines into names and functions that the source code can directly use. | |
#define | SLP_TR SLPTRPIN |
Pin number that corresponds to the SLP_TR pin. More... | |
#define | DDR_SLP_TR DDR( SLPTRPORT ) |
Data Direction Register that corresponds to the port where SLP_TR is connected. More... | |
#define | PORT_SLP_TR PORT( SLPTRPORT ) |
Port (Write Access) where SLP_TR is connected. More... | |
#define | PIN_SLP_TR PIN( SLPTRPORT ) |
Pin (Read Access) where SLP_TR is connected. More... | |
#define | hal_set_slptr_high() ( PORT_SLP_TR |= ( 1 << SLP_TR ) ) |
This macro pulls the SLP_TR pin high. More... | |
#define | hal_set_slptr_low() ( PORT_SLP_TR &= ~( 1 << SLP_TR ) ) |
This macro pulls the SLP_TR pin low. More... | |
#define | hal_get_slptr() ( PIN_SLP_TR & ( 1 << SLP_TR ) ) |
Read current state of the SLP_TR pin (High/Low). More... | |
#define | RST RSTPIN |
Pin number that corresponds to the RST pin. More... | |
#define | DDR_RST DDR( RSTPORT ) |
Data Direction Register that corresponds to the port where RST is. | |
#define | PORT_RST PORT( RSTPORT ) |
Port (Write Access) where RST is connected. More... | |
#define | PIN_RST PIN( RSTPORT /* BUG? */) |
Pin (Read Access) where RST is connected. More... | |
#define | hal_set_rst_high() ( PORT_RST |= ( 1 << RST ) ) |
This macro pulls the RST pin high. More... | |
#define | hal_set_rst_low() ( PORT_RST &= ~( 1 << RST ) ) |
This macro pulls the RST pin low. More... | |
#define | hal_get_rst() ( ( PIN_RST & ( 1 << RST ) ) >> RST ) |
Read current state of the RST pin (High/Low). More... | |
#define | HAL_SS_PIN SSPIN |
The slave select pin. More... | |
#define | HAL_SCK_PIN SCKPIN |
Data bit for SCK. More... | |
#define | HAL_MOSI_PIN MOSIPIN |
#define | HAL_MISO_PIN MISOPIN |
#define | HAL_PORT_SPI PORT( SPIPORT ) |
The SPI module is located on PORTB. More... | |
#define | HAL_PORT_SS PORT( SSPORT ) |
#define | HAL_PORT_SCK PORT( SCKPORT ) |
#define | HAL_PORT_MOSI PORT( MOSIPORT ) |
The SPI module uses GPIO might be split on different ports. More... | |
#define | HAL_PORT_MISO PORT( MISOPORT ) |
The SPI module uses GPIO might be split on different ports. More... | |
#define | HAL_DDR_SPI DDR( SPIPORT ) |
Data Direction Register for PORTB. More... | |
#define | HAL_DDR_SS DDR( SSPORT ) |
Data Direction Register for MISO GPIO pin. More... | |
#define | HAL_DDR_SCK DDR( SCKPORT ) |
Data Direction Register for MISO GPIO pin. More... | |
#define | HAL_DDR_MOSI DDR( MOSIPORT ) |
Data Direction Register for MISO GPIO pin. More... | |
#define | HAL_DDR_MISO DDR( MISOPORT ) |
Data Direction Register for MOSI GPIO pin. More... | |
#define | HAL_DD_SS SSPIN |
Data Direction bit for SS. More... | |
#define | HAL_DD_SCK SCKPIN |
Data Direction bit for SCK. More... | |
#define | HAL_DD_MOSI MOSIPIN |
Data Direction bit for MOSI. More... | |
#define | HAL_DD_MISO MISOPIN |
Data Direction bit for MISO. More... | |
Macros for radio operation. | |
#define | HAL_BAT_LOW_MASK ( 0x80 ) |
Mask for the BAT_LOW interrupt. More... | |
#define | HAL_TRX_UR_MASK ( 0x40 ) |
Mask for the TRX_UR interrupt. More... | |
#define | HAL_TRX_END_MASK ( 0x08 ) |
Mask for the TRX_END interrupt. More... | |
#define | HAL_RX_START_MASK ( 0x04 ) |
Mask for the RX_START interrupt. More... | |
#define | HAL_PLL_UNLOCK_MASK ( 0x02 ) |
Mask for the PLL_UNLOCK interrupt. More... | |
#define | HAL_PLL_LOCK_MASK ( 0x01 ) |
Mask for the PLL_LOCK interrupt. More... | |
#define | HAL_MIN_FRAME_LENGTH ( 0x03 ) |
A frame should be at least 3 bytes. More... | |
#define | HAL_MAX_FRAME_LENGTH ( 0x7F ) |
A frame should no more than 127 bytes. More... | |
HAL function names have the following conventions:
HAL which SimpleMAC library depends upon: API that is required for proper operation of the SimpleMAC library. As with all of the HAL, it is provided as source and it is possible for the end customer to modify this code. However, unlike other portions of the HAL, if the customer does modify this code, it must ensure that equivalent functionality is still provided to ensure proper operation of the SimpleMAC library.
HAL for other chip capabilities: API which SimpleMAC does not directly depend on. However, much of this functionality may be required for proper operation of all features of the chip.
Additional HAL for sample applications: API which is included to assist the development of the included sample applications. This functionality may be very useful, but is not required for proper operation of the chip. This code and functionality may be freely modified by the end customer.
See also hal.h.
#define AVR_ENTER_CRITICAL_REGION | ( | ) | {uint8_t volatile saved_sreg = SREG; cli( ) |
This macro will protect the following code from interrupts.
Definition at line 314 of file hal.h.
Referenced by calibrate_rc_osc_32k(), hal_clear_bat_low_flag(), hal_clear_pll_lock_flag(), hal_clear_rx_start_event_handler(), hal_clear_trx_end_event_handler(), hal_frame_read(), hal_frame_write(), hal_register_read(), hal_register_write(), hal_reset_flags(), hal_set_rx_start_event_handler(), hal_set_trx_end_event_handler(), hal_sram_read(), hal_sram_write(), and sicslowmac_resetRequest().
#define AVR_LEAVE_CRITICAL_REGION | ( | ) | SREG = saved_sreg;} |
This macro must always be used in conjunction with AVR_ENTER_CRITICAL_REGION so that interrupts are enabled again.
Definition at line 318 of file hal.h.
Referenced by calibrate_rc_osc_32k(), hal_clear_bat_low_flag(), hal_clear_pll_lock_flag(), hal_clear_rx_start_event_handler(), hal_clear_trx_end_event_handler(), hal_frame_read(), hal_frame_write(), hal_register_read(), hal_register_write(), hal_reset_flags(), hal_set_rx_start_event_handler(), hal_set_trx_end_event_handler(), hal_sram_read(), hal_sram_write(), and sicslowmac_resetRequest().
#define DDR_SLP_TR DDR( SLPTRPORT ) |
Data Direction Register that corresponds to the port where SLP_TR is connected.
Definition at line 246 of file hal.h.
Referenced by hal_init().
#define DDR_SLP_TR DDR( SLPTRPORT ) |
#define HAL_BAT_LOW_MASK ( 0x80 ) |
Mask for the BAT_LOW interrupt.
Definition at line 336 of file hal.h.
Referenced by hal_frame_read().
#define HAL_BAT_LOW_MASK ( 0x80 ) |
#define HAL_CALCULATED_CRC_OK (0) |
CRC calculated over the frame including the CRC field should be 0.
Definition at line 82 of file hal.c.
Referenced by hal_frame_read().
#define HAL_DD_MOSI MOSIPIN |
#define HAL_DD_SCK SCKPIN |
#define HAL_DD_SS SSPIN |
#define HAL_DDR_MISO DDR( MISOPORT ) |
#define HAL_DDR_MOSI DDR( MOSIPORT ) |
#define HAL_DDR_SCK DDR( SCKPORT ) |
#define HAL_DDR_SPI DDR( SPIPORT ) |
#define HAL_DDR_SPI DDR( SPIPORT ) |
#define HAL_DDR_SS DDR( SSPORT ) |
#define hal_disable_trx_interrupt | ( | ) | HAL_DISABLE_RADIO_INTERRUPT( ) |
#define hal_disable_trx_interrupt | ( | ) | HAL_DISABLE_RADIO_INTERRUPT( ) |
#define HAL_DUMMY_READ (0x00) |
#define HAL_ENABLE_RADIO_INTERRUPT | ( | ) | ( INT1IC.BYTE |= 1 ) |
#define HAL_ENTER_CRITICAL_REGION | ( | ) | MULLE_ENTER_CRITICAL_REGION( ) |
#define hal_get_slptr | ( | ) | ( ( PIN_SLP_TR & ( 1 << SLP_TR ) ) >> SLP_TR ) |
Read current state of the SLP_TR pin (High/Low).
Definition at line 251 of file hal.h.
Referenced by radio_is_sleeping().
#define hal_get_slptr | ( | ) | ( PIN_SLP_TR & ( 1 << SLP_TR ) ) |
#define HAL_LEAVE_CRITICAL_REGION | ( | ) | MULLE_LEAVE_CRITICAL_REGION( ) |
#define HAL_MAX_FRAME_LENGTH ( 0x7F ) |
A frame should no more than 127 bytes.
Definition at line 344 of file hal.h.
Referenced by hal_frame_read().
#define HAL_MAX_FRAME_LENGTH ( 0x7F ) |
#define HAL_MIN_FRAME_LENGTH ( 0x03 ) |
A frame should be at least 3 bytes.
Definition at line 343 of file hal.h.
Referenced by hal_frame_read().
#define HAL_MIN_FRAME_LENGTH ( 0x03 ) |
#define HAL_PLL_LOCK_MASK ( 0x01 ) |
Mask for the PLL_LOCK interrupt.
Definition at line 341 of file hal.h.
Referenced by hal_frame_read().
#define HAL_PLL_LOCK_MASK ( 0x01 ) |
#define HAL_PLL_UNLOCK_MASK ( 0x02 ) |
Mask for the PLL_UNLOCK interrupt.
Definition at line 340 of file hal.h.
Referenced by hal_frame_read().
#define HAL_PLL_UNLOCK_MASK ( 0x02 ) |
#define HAL_PORT_MISO PORT( MISOPORT ) |
#define HAL_PORT_MOSI PORT( MOSIPORT ) |
#define HAL_PORT_SPI PORT( SPIPORT ) |
#define HAL_PORT_SPI PORT( SPIPORT ) |
#define HAL_RX_START_MASK ( 0x04 ) |
Mask for the RX_START interrupt.
Definition at line 339 of file hal.h.
Referenced by hal_frame_read().
#define HAL_RX_START_MASK ( 0x04 ) |
This macro pulls the RST pin high.
Definition at line 256 of file hal.h.
Referenced by radio_reset_trx().
This macro pulls the RST pin low.
Definition at line 257 of file hal.h.
Referenced by radio_reset_trx().
#define hal_set_slptr_high | ( | ) | ( PORT_SLP_TR |= ( 1 << SLP_TR ) ) |
This macro pulls the SLP_TR pin high.
Definition at line 249 of file hal.h.
Referenced by radio_enter_sleep_mode(), and radio_send_data().
#define hal_set_slptr_high | ( | ) | ( PORT_SLP_TR |= ( 1 << SLP_TR ) ) |
#define hal_set_slptr_low | ( | ) | ( PORT_SLP_TR &= ~( 1 << SLP_TR ) ) |
This macro pulls the SLP_TR pin low.
Definition at line 250 of file hal.h.
Referenced by radio_leave_sleep_mode(), radio_reset_state_machine(), radio_reset_trx(), and radio_send_data().
#define hal_set_slptr_low | ( | ) | ( PORT_SLP_TR &= ~( 1 << SLP_TR ) ) |
#define HAL_SPI_TRANSFER_OPEN | ( | ) |
This function is called when a rx_start interrupt is signaled.
If this function pointer is set to something else than NULL, it will be called when a RX_START event is signaled. The function takes two parameters: timestamp in IEEE 802.15.4 symbols (16 us resolution) and frame length. The event handler will be called in the interrupt domain, so the function must be kept short and not be blocking! Otherwise the system performance will be greatly degraded.
If this function pointer is set to something else than NULL, it will be called when a TRX_END event is signaled. The function takes one parameter: timestamp in IEEE 802.15.4 symbols (16 us resolution). The event handler will be called in the interrupt domain, so the function must not block!
Definition at line 172 of file halbb.c.
Referenced by hal_frame_read().
#define HAL_SS_HIGH | ( | ) | (HAL_PORT_SPI |= ( 1 << HAL_SS_PIN )) |
MACRO for pulling SS high.
Definition at line 269 of file hal.h.
Referenced by hal_frame_read(), hal_frame_write(), hal_register_read(), hal_register_write(), hal_sram_read(), and hal_sram_write().
#define HAL_SS_HIGH | ( | ) | (HAL_PORT_SS |= ( 1 << HAL_SS_PIN )) |
#define HAL_SS_LOW | ( | ) | (HAL_PORT_SPI &= ~( 1 << HAL_SS_PIN )) |
MACRO for pulling SS low.
Definition at line 270 of file hal.h.
Referenced by hal_frame_read(), hal_frame_write(), hal_register_read(), hal_register_write(), hal_sram_read(), and hal_sram_write().
#define HAL_SS_LOW | ( | ) | (HAL_PORT_SS &= ~( 1 << HAL_SS_PIN )) |
#define HAL_TRX_CMD_FR (0x20) |
Frame Receive Mode (long mode).
Definition at line 77 of file hal.c.
Referenced by hal_frame_read().
#define HAL_TRX_CMD_FW (0x60) |
Frame Transmit Mode (long mode).
Definition at line 76 of file hal.c.
Referenced by hal_frame_write().
#define HAL_TRX_CMD_RADDRM (0x7F) |
Register Address Mask.
Definition at line 80 of file hal.c.
Referenced by hal_frame_write(), hal_register_read(), and hal_register_write().
#define HAL_TRX_CMD_RR (0x80) |
#define HAL_TRX_CMD_RW (0xC0) |
Register Write (short mode).
Definition at line 74 of file hal.c.
Referenced by hal_register_write().
#define HAL_TRX_CMD_SR (0x00) |
#define HAL_TRX_CMD_SW (0x40) |
#define HAL_TRX_END_MASK ( 0x08 ) |
Mask for the TRX_END interrupt.
Definition at line 338 of file hal.h.
Referenced by hal_frame_read().
#define HAL_TRX_END_MASK ( 0x08 ) |
#define HAL_TRX_UR_MASK ( 0x40 ) |
Mask for the TRX_UR interrupt.
Definition at line 337 of file hal.h.
Referenced by hal_frame_read().
#define HAL_TRX_UR_MASK ( 0x40 ) |
#define PIN_RST PIN( RSTPORT ) |
#define PIN_RST PIN( RSTPORT /* BUG? */) |
#define PIN_SLP_TR PIN( SLPTRPORT ) |
#define PIN_SLP_TR PIN( SLPTRPORT ) |
#define PORT_RST PORT( RSTPORT ) |
#define PORT_RST PORT( RSTPORT ) |
#define PORT_SLP_TR PORT( SLPTRPORT ) |
#define PORT_SLP_TR PORT( SLPTRPORT ) |
#define RADIO_VECT TIMER1_CAPT_vect |
#define RST RSTPIN |
Pin number that corresponds to the RST pin.
Definition at line 252 of file hal.h.
Referenced by hal_init().
#define RST RSTPIN |
#define SLP_TR SLPTRPIN |
Pin number that corresponds to the SLP_TR pin.
Definition at line 245 of file hal.h.
Referenced by hal_init().
#define SLP_TR SLPTRPIN |
typedef void(* hal_rx_start_isr_event_handler_t)(uint32_t const isr_timestamp, uint8_t const frame_length) |
RX_START event handler callback type.
Is called with timestamp in IEEE 802.15.4 symbols and frame length. See hal_set_rx_start_event_handler().
typedef void(* hal_rx_start_isr_event_handler_t)(uint32_t const isr_timestamp, uint8_t const frame_length) |
RX_START event handler callback type.
Is called with timestamp in IEEE 802.15.4 symbols and frame length. See hal_set_rx_start_event_handler().
typedef void(* hal_trx_end_isr_event_handler_t)(uint32_t const isr_timestamp) |
RRX_END event handler callback type.
Is called with timestamp in IEEE 802.15.4 symbols and frame length. See hal_set_trx_end_event_handler().
typedef void(* hal_trx_end_isr_event_handler_t)(uint32_t const isr_timestamp) |
RRX_END event handler callback type.
Is called with timestamp in IEEE 802.15.4 symbols and frame length. See hal_set_trx_end_event_handler().
void hal_frame_read | ( | hal_rx_frame_t * | rx_frame, |
rx_callback_t | rx_callback | ||
) |
This function will upload a frame from the radio transceiver's frame buffer.
If the frame currently available in the radio transceiver's frame buffer is out of the defined bounds. Then the frame length, lqi value and crc be set to zero. This is done to indicate an error.
rx_frame | Pointer to the data structure where the frame is stored. |
rx_callback | Pointer to callback function for receiving one byte at a time. |
Definition at line 430 of file hal.c.
References AVR_ENTER_CRITICAL_REGION, AVR_LEAVE_CRITICAL_REGION, hal_rx_frame_t::crc, hal_rx_frame_t::data, HAL_CALCULATED_CRC_OK, HAL_MAX_FRAME_LENGTH, HAL_MIN_FRAME_LENGTH, HAL_SS_HIGH, HAL_SS_LOW, HAL_TRX_CMD_FR, hal_rx_frame_t::length, and hal_rx_frame_t::lqi.
Referenced by hal_frame_read().
void hal_frame_read | ( | hal_rx_frame_t * | rx_frame | ) |
This function will upload a frame from the radio transceiver's frame buffer.
If the frame currently available in the radio transceiver's frame buffer is out of the defined bounds. Then the frame length, lqi value and crc be set to zero. This is done to indicate an error. This version is optimized for use with contiki RF230BB driver. The callback routine and CRC are left out for speed in reading the rx buffer. Any delays here can lead to overwrites by the next packet!
rx_frame | Pointer to the data structure where the frame is stored. |
rx_callback | Pointer to callback function for receiving one byte at a time. |
Definition at line 587 of file halbb.c.
References BUSY_RX, BUSY_RX_AACK, hal_rx_frame_t::crc, hal_rx_frame_t::data, HAL_BAT_LOW_MASK, hal_frame_read(), hal_frame_write(), HAL_PLL_LOCK_MASK, HAL_PLL_UNLOCK_MASK, hal_register_read(), hal_register_write(), HAL_RF230_ISR, HAL_RX_START_MASK, HAL_SPI_TRANSFER_OPEN, hal_sram_read(), hal_subregister_read(), HAL_TRX_END_MASK, HAL_TRX_UR_MASK, hal_rx_frame_t::length, hal_rx_frame_t::lqi, RADIO_VECT(), RG_IRQ_MASK, RG_IRQ_STATUS, RG_PHY_ED_LEVEL, RX_AACK_ON, RX_ON, SR_RSSI, SR_TRX_STATUS, and TIMER1_OVF_vect().
void hal_frame_write | ( | uint8_t * | write_buffer, |
uint8_t | length | ||
) |
This function will download a frame to the radio transceiver's frame buffer.
write_buffer | Pointer to data that is to be written to frame buffer. |
length | Length of data. The maximum length is 127 bytes. |
Definition at line 517 of file hal.c.
References AVR_ENTER_CRITICAL_REGION, AVR_LEAVE_CRITICAL_REGION, HAL_SS_HIGH, HAL_SS_LOW, HAL_TRX_CMD_FW, and HAL_TRX_CMD_RADDRM.
Referenced by hal_frame_read(), and radio_send_data().
uint8_t hal_get_bat_low_flag | ( | void | ) |
uint8_t hal_get_pll_lock_flag | ( | void | ) |
This function returns the current value of the PLL_LOCK flag.
The PLL_LOCK flag is incremented each time a PLL_LOCK event is signaled from the radio transceiver. This way it is possible for the end user to poll the flag for new event occurances.
Definition at line 278 of file hal.c.
Referenced by radio_calibrate_pll().
hal_rx_start_isr_event_handler_t hal_get_rx_start_event_handler | ( | void | ) |
uint8_t hal_register_read | ( | uint8_t | address | ) |
This function reads data from one of the radio transceiver's registers.
This function reset the interrupt flags and interrupt event handlers (Callbacks) to their default value.
address | Register address to read from. See datasheet for register map. |
This function returns the current value of the BAT_LOW flag.
The BAT_LOW flag is incremented each time a BAT_LOW event is signaled from the radio transceiver. This way it is possible for the end user to poll the flag for new event occurances.This function clears the BAT_LOW flag.This function is used to set new TRX_END event handler, overriding old handler reference.This function is used to set new TRX_END event handler, overriding old handler reference.Remove event handler reference.This function returns the active RX_START event handler
The PLL_LOCK flag is incremented each time a PLL_LOCK event is signaled from the radio transceiver. This way it is possible for the end user to poll the flag for new event occurances.This function clears the PLL_LOCK flag.This function reads data from one of the radio transceiver's registers.
address | Register address to read from. See datasheet for register map. |
Definition at line 305 of file hal.c.
References AVR_ENTER_CRITICAL_REGION, AVR_LEAVE_CRITICAL_REGION, HAL_SS_HIGH, HAL_SS_LOW, HAL_TRX_CMD_RADDRM, and HAL_TRX_CMD_RR.
Referenced by hal_frame_read(), hal_subregister_read(), hal_subregister_write(), radio_get_extended_address(), radio_get_pan_id(), radio_get_short_address(), and radio_init().
void hal_register_write | ( | uint8_t | address, |
uint8_t | value | ||
) |
This function writes a new value to one of the radio transceiver's registers.
address | Address of register to write. |
value | Value to write. |
Definition at line 343 of file hal.c.
References AVR_ENTER_CRITICAL_REGION, AVR_LEAVE_CRITICAL_REGION, HAL_SS_HIGH, HAL_SS_LOW, HAL_TRX_CMD_RADDRM, and HAL_TRX_CMD_RW.
Referenced by hal_frame_read(), hal_subregister_write(), radio_configure_csma(), radio_init(), radio_set_extended_address(), radio_set_pan_id(), and radio_set_short_address().
void hal_sram_read | ( | uint8_t | address, |
uint8_t | length, | ||
uint8_t * | data | ||
) |
Read SRAM.
This function reads from the SRAM of the radio transceiver.
address | Address in the TRX's SRAM where the read burst should start |
length | Length of the read burst |
data | Pointer to buffer where data is stored. |
Definition at line 559 of file hal.c.
References AVR_ENTER_CRITICAL_REGION, AVR_LEAVE_CRITICAL_REGION, HAL_DUMMY_READ, HAL_SS_HIGH, HAL_SS_LOW, and HAL_TRX_CMD_SR.
Referenced by hal_frame_read().
void hal_sram_write | ( | uint8_t | address, |
uint8_t | length, | ||
uint8_t * | data | ||
) |
Write SRAM.
This function writes into the SRAM of the radio transceiver.
address | Address in the TRX's SRAM where the write burst should start |
length | Length of the write burst |
data | Pointer to an array of bytes that should be written |
Definition at line 598 of file hal.c.
References AVR_ENTER_CRITICAL_REGION, AVR_LEAVE_CRITICAL_REGION, HAL_SS_HIGH, HAL_SS_LOW, and HAL_TRX_CMD_SW.
uint8_t hal_subregister_read | ( | uint8_t | address, |
uint8_t | mask, | ||
uint8_t | position | ||
) |
This function reads the value of a specific subregister.
address | Main register's address. |
mask | Bit mask of the subregister. |
position | Bit position of the subregister |
Value | of the read subregister. |
Definition at line 378 of file hal.c.
References hal_register_read().
Referenced by hal_frame_read(), radio_batmon_get_status(), radio_batmon_get_voltage_range(), radio_batmon_get_voltage_threshold(), radio_calibrate_filter(), radio_calibrate_pll(), radio_get_cca_mode(), radio_get_clock_speed(), radio_get_device_role(), radio_get_ed_threshold(), radio_get_operating_channel(), radio_get_rssi_value(), radio_get_trx_state(), and radio_get_tx_power_level().
void hal_subregister_write | ( | uint8_t | address, |
uint8_t | mask, | ||
uint8_t | position, | ||
uint8_t | value | ||
) |
This function writes a new value to one of the radio transceiver's subregisters.
address | Main register's address. |
mask | Bit mask of the subregister. |
position | Bit position of the subregister |
value | Value to write into the subregister. |
Definition at line 401 of file hal.c.
References hal_register_read(), and hal_register_write().
Referenced by mac_init(), radio_batmon_configure(), radio_calibrate_filter(), radio_calibrate_pll(), radio_configure_csma(), radio_init(), radio_reset_state_machine(), radio_set_cca_mode(), radio_set_clock_speed(), radio_set_device_role(), radio_set_operating_channel(), radio_set_trx_state(), radio_set_tx_power_level(), and radio_use_auto_tx_crc().
void RADIO_VECT | ( | void | ) |
ISR for the radio IRQ line, triggered by the input capture.
Read SRAM.
This is the interrupt service routine for timer1.ICIE1 input capture. It is triggered of a rising edge on the radio transceivers IRQ line.
This function reads from the SRAM of the radio transceiver.
address | Address in the TRX's SRAM where the read burst should start |
length | Length of the read burst |
data | Pointer to buffer where data is stored.Write SRAM |
This function writes into the SRAM of the radio transceiver. It can reduce SPI transfers if only part of a frame is to be changed before retransmission.
address | Address in the TRX's SRAM where the write burst should start |
length | Length of the write burst |
data | Pointer to an array of bytes that should be writtenISR for the radio IRQ line, triggered by the input capture. This is the interrupt service routine for timer1.ICIE1 input capture. It is triggered of a rising edge on the radio transceivers IRQ line. |
Referenced by hal_frame_read().