EPPL  0.1 alpha
 All Files Typedefs Groups Pages
eppl_avr8_reinit.h
Go to the documentation of this file.
1 /*
2  Copyright (c) 2013, Radoslaw Koppel
3  All rights reserved.
4 
5  Redistribution and use in source and binary forms, with or without
6  modification, are permitted provided that the following conditions are met:
7 
8  - Redistributions of source code must retain the above copyright
9  notice, this list of conditions and the following disclaimer.
10 
11  - Redistributions in binary form must reproduce the above copyright
12  notice, this list of conditions and the following disclaimer in the
13  documentation and/or other materials provided with the distribution.
14 
15  - Neither the name of the copyright holders nor the
16  names of its contributors may be used to endorse or promote products
17  derived from this software without specific prior written permission.
18 
19  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
20  ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
21  WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
22  DISCLAIMED. IN NO EVENT SHALL COPYRIGHT HOLDER BE LIABLE FOR ANY
23  DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
24  (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
25  LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
26  ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
28  SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 */
39 #ifndef EPPL_AVR8_REINIT_H_INCLUDED
40 #define EPPL_AVR8_REINIT_H_INCLUDED
41 
61  #define EPPL_avr8_reinit_isPORTSET(param, bit) ( (EPPL_PORTNR(bit) == param) && EPPL_avr8_mode_modifiedReg(PORT, EPPL_GRfrom(bit), EPPL_GRto(bit)) && EPPL_avr8_mode_valuePORT(EPPL_GRto(bit)) )
62 
66  #define EPPL_avr8_reinit_isPORTCLR(param, bit) ( (EPPL_PORTNR(bit) == param) && EPPL_avr8_mode_modifiedReg(PORT, EPPL_GRfrom(bit), EPPL_GRto(bit)) && !EPPL_avr8_mode_valuePORT(EPPL_GRto(bit)) )
67 
71  #define EPPL_avr8_reinit_isPORTCHANGE(param, bit) ( (EPPL_PORTNR(bit) == param) && EPPL_avr8_mode_modifiedReg(PORT, EPPL_GRfrom(bit), EPPL_GRto(bit)) )
72 
76  #define EPPL_avr8_reinit_isPORTUNSAFE(param, bit) ( (EPPL_PORTNR(bit) == param) && ( !EPPL_avr8_mode_knownPORT(EPPL_GRto(bit)) || EPPL_avr8_mode_modifiedReg(PORT, EPPL_GRfrom(bit), EPPL_GRto(bit)) ) )
77 
82  #define EPPL_avr8_reinit_isDDRSET(param, bit) ( (EPPL_PORTNR(bit) == param) && EPPL_avr8_mode_modifiedReg(DDR, EPPL_GRfrom(bit), EPPL_GRto(bit)) && EPPL_avr8_mode_valueDDR(EPPL_GRto(bit)) )
83 
87  #define EPPL_avr8_reinit_isDDRCLR(param, bit) ( (EPPL_PORTNR(bit) == param) && EPPL_avr8_mode_modifiedReg(DDR, EPPL_GRfrom(bit), EPPL_GRto(bit)) && !EPPL_avr8_mode_valueDDR(EPPL_GRto(bit)) )
88 
92  #define EPPL_avr8_reinit_isDDRCHANGE(param, bit) ( (EPPL_PORTNR(bit) == param) && EPPL_avr8_mode_modifiedReg(DDR, EPPL_GRfrom(bit), EPPL_GRto(bit)) )
93 
97  #define EPPL_avr8_reinit_isDDRUNSAFE(param, bit) ( (EPPL_PORTNR(bit) == param) && ( !EPPL_avr8_mode_knownDDR(EPPL_GRto(bit)) || EPPL_avr8_mode_modifiedReg(DDR, EPPL_GRfrom(bit), EPPL_GRto(bit)) ) )
98 
109 #define EPPL_avr8_ReinitIsAtomicAccessReg(reg, port, pinconfigs...) \
110  ( \
111  (0 == EPPL_GETSUBSET(EPPL_avr8_reinit_is##reg##CHANGE, port, EPPL_extractPinPos, |, pinconfigs)) || \
112  (0xff == EPPL_GETSUBSET(EPPL_avr8_reinit_is##reg##CHANGE, port, EPPL_extractPinPos, |, pinconfigs)) || \
113  ((1 == EPPL_GETSUBSET(EPPL_avr8_reinit_is##reg##CHANGE, port, EPPL_extractOne, +, pinconfigs)) && EPPL_avr8_CheckRegSupportsBit(EPPL_avr8_CPORTREG(reg, port))) \
114  )
115 
121 #define EPPL_avr8_ReinitIsAtomic(port, pinconfigs...) \
122  ( \
123  EPPL_avr8_ReinitIsAtomicAccessReg(PORT, port, pinconfigs) && \
124  EPPL_avr8_ReinitIsAtomicAccessReg(DDR, port, pinconfigs) \
125  )
126 
142 #define eppl_avr8_ReinitReg(reg, port, pinconfigs...) \
143  do{ \
144  \
145  if(0 == EPPL_GETSUBSET(EPPL_avr8_reinit_is##reg##CHANGE, port, EPPL_extractPinPos, |, pinconfigs)) \
146  break; \
147  \
148  if(0xff == EPPL_GETSUBSET(EPPL_avr8_reinit_is##reg##CHANGE, port, EPPL_extractPinPos, |, pinconfigs)) { \
149  *EPPL_avr8_CPORTREG(reg, port) = EPPL_GETSUBSET(EPPL_avr8_reinit_is##reg##SET, port, EPPL_extractPinPos, |, pinconfigs); \
150  } \
151  \
152  else if((1 == EPPL_GETSUBSET(EPPL_avr8_reinit_is##reg##CHANGE, port, EPPL_extractOne, +, pinconfigs)) && EPPL_avr8_CheckRegSupportsBit(EPPL_avr8_CPORTREG(reg, port))) \
153  { \
154  if(0 != EPPL_GETSUBSET(EPPL_avr8_reinit_is##reg##SET, port, EPPL_extractPinPos, |, pinconfigs)) \
155  eppl_avr8_asm_sbi(EPPL_avr8_CPORTREG(reg, port), EPPL_GETSUBSET(EPPL_avr8_reinit_is##reg##SET, port, EPPL_extractPinNr, +, pinconfigs)); \
156  else \
157  eppl_avr8_asm_cbi(EPPL_avr8_CPORTREG(reg, port), EPPL_GETSUBSET(EPPL_avr8_reinit_is##reg##CLR, port, EPPL_extractPinNr, +, pinconfigs)); \
158  } \
159  \
160  else { \
161  *EPPL_avr8_CPORTREG(reg, port) = (*EPPL_avr8_CPORTREG(reg, port) | \
162  EPPL_GETSUBSET(EPPL_avr8_reinit_is##reg##SET, port, EPPL_extractPinPos, |, pinconfigs) ) & \
163  ~EPPL_GETSUBSET(EPPL_avr8_reinit_is##reg##CLR, port, EPPL_extractPinPos, |, pinconfigs); \
164  } \
165  }while(0)
166 
189 #define EPPL_avr8_ReinitIsSafe(port, pinconfigs...)\
190  (\
191  ( \
192  !EPPL_GETSUBSET(EPPL_avr8_reinit_isDDRUNSAFE, port, EPPL_extractPinPos, |, EPPL_HOTPINS) || \
193  EPPL_avr8_ReinitIsAtomicAccessReg(DDR, port, pinconfigs) \
194  ) && \
195  ( \
196  !EPPL_GETSUBSET(EPPL_avr8_reinit_isPORTUNSAFE, port, EPPL_extractPinPos, |, EPPL_HOTPINS) || \
197  EPPL_avr8_ReinitIsAtomicAccessReg(PORT, port, pinconfigs) \
198  ) \
199  )
200 
208 #define eppl_avr8_ReinitOnePort(port, pinconfigs...) \
209  do{\
210  eppl_avr8_ReinitReg(PORT, port, pinconfigs); \
211  eppl_avr8_ReinitReg(DDR, port, pinconfigs); \
212  }while(0)
213 
215 #endif /* EPPL_AVR8_REINIT_H_INCLUDED */