Contiki 2.5
Files | Data Structures | Macros | Typedefs | Functions
RF230 hardware level drivers

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.

Change these values to port to other platforms.

#define RAVEN_D   4
 
#define RAVENUSB_C   1
 
#define RCB_B   2
 
#define ZIGBIT   3
 
#define IRIS   5
 

Macros used to generate read register names from platform-specific definitions of ports.

The various CAT macros (DDR, PORT, and PIN) are used to assign port/pin/DDR names to various macro variables.

The variables are assigned based on the specific connections made in the hardware. For example TCCR(TICKTIMER,A) can be used in place of TCCR0A if TICKTIMER is defined as 0.

#define CAT(x, y)   x##y
 
#define CAT2(x, y, z)   x##y##z
 
#define DDR(x)   CAT(DDR, x)
 
#define PORT(x)   CAT(PORT, x)
 
#define PIN(x)   CAT(PIN, x)
 
#define UCSR(num, let)   CAT2(UCSR,num,let)
 
#define RXEN(x)   CAT(RXEN,x)
 
#define TXEN(x)   CAT(TXEN,x)
 
#define TXC(x)   CAT(TXC,x)
 
#define RXC(x)   CAT(RXC,x)
 
#define RXCIE(x)   CAT(RXCIE,x)
 
#define UCSZ(x, y)   CAT2(UCSZ,x,y)
 
#define UBRR(x, y)   CAT2(UBRR,x,y)
 
#define UDRE(x)   CAT(UDRE,x)
 
#define UDRIE(x)   CAT(UDRIE,x)
 
#define UDR(x)   CAT(UDR,x)
 
#define TCNT(x)   CAT(TCNT,x)
 
#define TIMSK(x)   CAT(TIMSK,x)
 
#define TCCR(x, y)   CAT2(TCCR,x,y)
 
#define COM(x, y)   CAT2(COM,x,y)
 
#define OCR(x, y)   CAT2(OCR,x,y)
 
#define CS(x, y)   CAT2(CS,x,y)
 
#define WGM(x, y)   CAT2(WGM,x,y)
 
#define OCIE(x, y)   CAT2(OCIE,x,y)
 
#define COMPVECT(x)   CAT2(TIMER,x,_COMPA_vect)
 
#define UDREVECT(x)   CAT2(USART,x,_UDRE_vect)
 
#define RXVECT(x)   CAT2(USART,x,_RX_vect)
 

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...
 

This is the list of pin configurations needed for a given platform.

Change these values to port to other platforms.

#define RAVEN_D   4
 
#define RAVENUSB_C   1
 
#define INGA_12   1
 
#define RCB_B   2
 
#define ZIGBIT   3
 
#define ATMEGA128RFA1   4
 
#define IRIS   5
 
#define SSPORT   SPIPORT
 
#define SCKPORT   SPIPORT
 
#define MOSIPORT   SPIPORT
 
#define MISOPORT   SPIPORT
 

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...
 

Detailed Description

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.

Macro Definition Documentation

#define AVR_ENTER_CRITICAL_REGION ( )    {uint8_t volatile saved_sreg = SREG; cli( )
#define AVR_LEAVE_CRITICAL_REGION ( )    SREG = saved_sreg;}
#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 )

Data Direction Register that corresponds to the port where SLP_TR is connected.

Definition at line 375 of file hal.h.

#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 )

Mask for the BAT_LOW interrupt.

Definition at line 498 of file hal.h.

#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_MISO   MISOPIN

Data Direction bit for MISO.

Definition at line 265 of file hal.h.

#define HAL_DD_MISO   MISOPIN

Data Direction bit for MISO.

Definition at line 406 of file hal.h.

#define HAL_DD_MOSI   MOSIPIN

Data Direction bit for MOSI.

Definition at line 264 of file hal.h.

Referenced by hal_init().

#define HAL_DD_MOSI   MOSIPIN

Data Direction bit for MOSI.

Definition at line 405 of file hal.h.

#define HAL_DD_SCK   SCKPIN

Data Direction bit for SCK.

Definition at line 263 of file hal.h.

Referenced by hal_init().

#define HAL_DD_SCK   SCKPIN

Data Direction bit for SCK.

Definition at line 404 of file hal.h.

#define HAL_DD_SS   SSPIN

Data Direction bit for SS.

Definition at line 262 of file hal.h.

Referenced by hal_init().

#define HAL_DD_SS   SSPIN

Data Direction bit for SS.

Definition at line 403 of file hal.h.

#define HAL_DDR_MISO   DDR( MISOPORT )

Data Direction Register for MOSI GPIO pin.

Definition at line 402 of file hal.h.

#define HAL_DDR_MOSI   DDR( MOSIPORT )

Data Direction Register for MISO GPIO pin.

Definition at line 401 of file hal.h.

#define HAL_DDR_SCK   DDR( SCKPORT )

Data Direction Register for MISO GPIO pin.

Definition at line 400 of file hal.h.

#define HAL_DDR_SPI   DDR( SPIPORT )

Data Direction Register for PORTB.

Definition at line 261 of file hal.h.

Referenced by hal_init().

#define HAL_DDR_SPI   DDR( SPIPORT )

Data Direction Register for PORTB.

Definition at line 398 of file hal.h.

#define HAL_DDR_SS   DDR( SSPORT )

Data Direction Register for MISO GPIO pin.

Definition at line 399 of file hal.h.

#define hal_disable_trx_interrupt ( )    HAL_DISABLE_RADIO_INTERRUPT( )

Disable the interrupt from the radio transceiver.

Return values
0if the pin is low, 1 if the pin is high.

Definition at line 329 of file hal.h.

#define hal_disable_trx_interrupt ( )    HAL_DISABLE_RADIO_INTERRUPT( )

Disable the interrupt from the radio transceiver.

Return values
0if the pin is low, 1 if the pin is high.

Definition at line 491 of file hal.h.

#define HAL_DUMMY_READ   (0x00)

Dummy value for the SPI.

Definition at line 72 of file hal.c.

Referenced by hal_sram_read().

#define HAL_ENABLE_RADIO_INTERRUPT ( )    ( INT1IC.BYTE |= 1 )

Macros defined for HAL_TIMER1.

These macros are used to define the correct setupt of the AVR's Timer1, and to ensure that the hal_get_system_time function returns the system time in symbols (16 us ticks).

Definition at line 467 of file hal.h.

#define HAL_ENTER_CRITICAL_REGION ( )    MULLE_ENTER_CRITICAL_REGION( )

This macro will protect the following code from interrupts.

Definition at line 474 of file hal.h.

#define hal_get_rst ( )    ( ( PIN_RST & ( 1 << RST ) ) >> RST )

Read current state of the RST pin (High/Low).

Definition at line 258 of file hal.h.

#define hal_get_rst ( )    ( ( PIN_RST & ( 1 << RST ) ) >> RST )

Read current state of the RST pin (High/Low).

Definition at line 388 of file hal.h.

#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 ) )

Read current state of the SLP_TR pin (High/Low).

Definition at line 381 of file hal.h.

#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.

Definition at line 478 of file hal.h.

#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 )

A frame should no more than 127 bytes.

Definition at line 506 of file hal.h.

#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 )

A frame should be at least 3 bytes.

Definition at line 505 of file hal.h.

#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 )

Mask for the PLL_LOCK interrupt.

Definition at line 503 of file hal.h.

#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 )

Mask for the PLL_UNLOCK interrupt.

Definition at line 502 of file hal.h.

#define HAL_PORT_MISO   PORT( MISOPORT )

The SPI module uses GPIO might be split on different ports.

Definition at line 397 of file hal.h.

#define HAL_PORT_MOSI   PORT( MOSIPORT )

The SPI module uses GPIO might be split on different ports.

Definition at line 396 of file hal.h.

#define HAL_PORT_SPI   PORT( SPIPORT )

The SPI module is located on PORTB.

Definition at line 260 of file hal.h.

Referenced by hal_init().

#define HAL_PORT_SPI   PORT( SPIPORT )

The SPI module is located on PORTB.

Definition at line 393 of file hal.h.

#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 )

Mask for the RX_START interrupt.

Definition at line 501 of file hal.h.

#define HAL_SCK_PIN   SCKPIN

Data bit for SCK.

Definition at line 390 of file hal.h.

#define hal_set_rst_high ( )    ( PORT_RST |= ( 1 << RST ) )

This macro pulls the RST pin high.

Definition at line 256 of file hal.h.

Referenced by radio_reset_trx().

#define hal_set_rst_high ( )    ( PORT_RST |= ( 1 << RST ) )

This macro pulls the RST pin high.

Definition at line 386 of file hal.h.

#define hal_set_rst_low ( )    ( PORT_RST &= ~( 1 << RST ) )

This macro pulls the RST pin low.

Definition at line 257 of file hal.h.

Referenced by radio_reset_trx().

#define hal_set_rst_low ( )    ( PORT_RST &= ~( 1 << RST ) )

This macro pulls the RST pin low.

Definition at line 387 of file hal.h.

#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 ) )

This macro pulls the SLP_TR pin high.

Definition at line 378 of file hal.h.

#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 ) )

This macro pulls the SLP_TR pin low.

Definition at line 379 of file hal.h.

#define HAL_SPI_TRANSFER_OPEN ( )
Value:
{ uint8_t spiTemp; \
HAL_ENTER_CRITICAL_REGION(); \
HAL_SS_LOW(); /* Start the SPI transaction by pulling the Slave Select low. */

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.
See Also
hal_set_rx_start_event_handlerThis function is called when a trx_end interrupt is signaled.
   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!
hal_set_trx_end_event_handler

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 ))

MACRO for pulling SS high.

Definition at line 412 of file hal.h.

#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 ))

MACRO for pulling SS low.

Definition at line 413 of file hal.h.

#define HAL_SS_PIN   SSPIN

The slave select pin.

Definition at line 259 of file hal.h.

#define HAL_SS_PIN   SSPIN

The slave select pin.

Definition at line 389 of file hal.h.

#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)

Register Read (short mode).

Definition at line 75 of file hal.c.

Referenced by hal_register_read().

#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)

SRAM Read.

Definition at line 79 of file hal.c.

Referenced by hal_sram_read().

#define HAL_TRX_CMD_SW   (0x40)

SRAM Write.

Definition at line 78 of file hal.c.

Referenced by hal_sram_write().

#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 )

Mask for the TRX_END interrupt.

Definition at line 500 of file hal.h.

#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 )

Mask for the TRX_UR interrupt.

Definition at line 499 of file hal.h.

#define PIN_RST   PIN( RSTPORT )

Pin (Read Access) where RST is connected.

Definition at line 255 of file hal.h.

#define PIN_RST   PIN( RSTPORT /* BUG? */)

Pin (Read Access) where RST is connected.

Definition at line 385 of file hal.h.

#define PIN_SLP_TR   PIN( SLPTRPORT )

Pin (Read Access) where SLP_TR is connected.

Definition at line 248 of file hal.h.

#define PIN_SLP_TR   PIN( SLPTRPORT )

Pin (Read Access) where SLP_TR is connected.

Definition at line 377 of file hal.h.

#define PORT_RST   PORT( RSTPORT )

Port (Write Access) where RST is connected.

Definition at line 254 of file hal.h.

#define PORT_RST   PORT( RSTPORT )

Port (Write Access) where RST is connected.

Definition at line 384 of file hal.h.

#define PORT_SLP_TR   PORT( SLPTRPORT )

Port (Write Access) where SLP_TR is connected.

Definition at line 247 of file hal.h.

#define PORT_SLP_TR   PORT( SLPTRPORT )

Port (Write Access) where SLP_TR is connected.

Definition at line 376 of file hal.h.

#define RADIO_VECT   TIMER1_CAPT_vect

Macros defined for HAL_TIMER1.

These macros are used to define the correct setupt of the AVR's Timer1, and to ensure that the hal_get_system_time function returns the system time in symbols (16 us ticks).

Definition at line 305 of file hal.h.

#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

Pin number that corresponds to the RST pin.

Definition at line 382 of file hal.h.

#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

Pin number that corresponds to the SLP_TR pin.

Definition at line 374 of file hal.h.

Typedef Documentation

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().

Definition at line 360 of file hal.h.

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().

Definition at line 522 of file hal.h.

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().

Definition at line 363 of file hal.h.

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().

Definition at line 525 of file hal.h.

Function Documentation

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.
Parameters
rx_framePointer to the data structure where the frame is stored.
rx_callbackPointer 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!
Parameters
rx_framePointer to the data structure where the frame is stored.
rx_callbackPointer 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.

Parameters
write_bufferPointer to data that is to be written to frame buffer.
lengthLength 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  )

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.

Definition at line 187 of file hal.c.

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  )

This function returns the active RX_START event handler.

Returns
Current RX_START event handler registered.

Definition at line 242 of file hal.c.

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.

Parameters
addressRegister address to read from. See datasheet for register map.
See Also
Look at the at86rf230_registermap.h file for register address definitions.
Returns
The actual value of the read register.

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

Returns
Current RX_START event handler registered.This function is used to set new RX_START event handler, overriding old handler reference.Remove event handler reference.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.This function clears the PLL_LOCK flag.This function reads data from one of the radio transceiver's registers.

Parameters
addressRegister address to read from. See datasheet for register map.
See Also
Look at the at86rf230_registermap.h file for register address definitions.
Returns
The actual value of the read register.

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.

See Also
Look at the at86rf230_registermap.h file for register address definitions.
Parameters
addressAddress of register to write.
valueValue 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.

Parameters
addressAddress in the TRX's SRAM where the read burst should start
lengthLength of the read burst
dataPointer 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.

Parameters
addressAddress in the TRX's SRAM where the write burst should start
lengthLength of the write burst
dataPointer 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.

See Also
Look at the at86rf230_registermap.h file for register and subregister definitions.
Parameters
addressMain register's address.
maskBit mask of the subregister.
positionBit position of the subregister
Return values
Valueof 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.

See Also
Look at the at86rf230_registermap.h file for register and subregister definitions.
Parameters
addressMain register's address.
maskBit mask of the subregister.
positionBit position of the subregister
valueValue 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.

Parameters
addressAddress in the TRX's SRAM where the read burst should start
lengthLength of the read burst
dataPointer 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.

Parameters
addressAddress in the TRX's SRAM where the write burst should start
lengthLength of the write burst
dataPointer 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().