AVR Z-LINKŪ


compiler_avr.h File Reference


Detailed Description

This file implements some macros that makes the IAR C-compiler and avr-gcc work with the same code base for the AVR architecture.

Application note:
AVR2001: AT86RF230 Software Programmer's Guide
Documentation
For comprehensive code documentation, supported compilers, compiler settings and supported devices see readme.html
Author:
Atmel Corporation: http://www.atmel.com
Support email: avr@atmel.com
$Name$
Revision
613
$RCSfile$
Date
2006-04-07 14:40:07 +0200 (fr, 07 apr 2006)

Copyright (c) 2006, Atmel Corporation All rights reserved.

Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.

2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.

3. The name of ATMEL may not be used to endorse or promote products derived from this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY ATMEL ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE EXPRESSLY AND SPECIFICALLY DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

Definition in file compiler_avr.h.

Go to the source code of this file.

Defines

#define AVR_ENTER_CRITICAL_REGION()   uint8_t volatile saved_sreg = SREG; cli( );
#define AVR_LEAVE_CRITICAL_REGION()   SREG = saved_sreg;


Define Documentation

 
#define AVR_ENTER_CRITICAL_REGION (  )     uint8_t volatile saved_sreg = SREG; cli( );

This macro will protect the following code from interrupts.

Definition at line 54 of file compiler_avr.h.

Referenced by hal_clear_bat_low_flag(), hal_clear_pll_lock_flag(), hal_clear_pll_unlock_flag(), hal_clear_rx_start_event_handler(), hal_clear_rx_start_flag(), hal_clear_trx_end_event_handler(), hal_clear_trx_end_flag(), hal_clear_trx_ur_flag(), hal_clear_unknown_isr_flag(), hal_frame_read(), hal_frame_write(), hal_get_system_time(), hal_register_read(), hal_register_write(), hal_reset_flags(), hal_set_rx_start_event_handler(), hal_set_trx_end_event_handler(), hal_sram_read(), and hal_sram_write().

 
#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 58 of file compiler_avr.h.

Referenced by hal_clear_bat_low_flag(), hal_clear_pll_lock_flag(), hal_clear_pll_unlock_flag(), hal_clear_rx_start_event_handler(), hal_clear_rx_start_flag(), hal_clear_trx_end_event_handler(), hal_clear_trx_end_flag(), hal_clear_trx_ur_flag(), hal_clear_unknown_isr_flag(), hal_frame_read(), hal_frame_write(), hal_get_system_time(), hal_register_read(), hal_register_write(), hal_reset_flags(), hal_set_rx_start_event_handler(), hal_set_trx_end_event_handler(), hal_sram_read(), and hal_sram_write().

@DOC_TITLE@
Generated on Wed Jul 11 18:16:31 2007 for AVR2001 AT86RF230 Software Programmer's Manual by doxygen 1.4.7