Menu

canID.h

Go to the documentation of this file.
00001 /*******************************************************************************
00002  *
00003  * Copyright (c) 2008-2010 Michael Schulze <mschulze@ivs.cs.uni-magdeburg.de>
00004  * All rights reserved.
00005  *
00006  *    Redistribution and use in source and binary forms, with or without
00007  *    modification, are permitted provided that the following conditions
00008  *    are met:
00009  *
00010  *    * Redistributions of source code must retain the above copyright
00011  *      notice, this list of conditions and the following disclaimer.
00012  *
00013  *    * Redistributions in binary form must reproduce the above copyright
00014  *      notice, this list of conditions and the following disclaimer in
00015  *      the documentation and/or other materials provided with the
00016  *      distribution.
00017  *
00018  *    * Neither the name of the copyright holders nor the names of
00019  *      contributors may be used to endorse or promote products derived
00020  *      from this software without specific prior written permission.
00021  *
00022  *
00023  *    THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
00024  *    IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
00025  *    TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
00026  *    PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
00027  *    OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
00028  *    SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
00029  *    LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
00030  *    DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
00031  *    THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
00032  *    (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
00033  *    OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00034  *
00035  *
00036  * $Id$
00037  *
00038  ******************************************************************************/
00039 
00040 #ifndef __canID_h__
00041 #define __canID_h__
00042 
00043 #include <stdint.h>
00044 
00045 namespace famouso {
00046     namespace mw {
00047         namespace nl {
00048             namespace CAN {
00049                 namespace detail {
00050 
00071                     template <typename IDStruct>
00072                     union __attribute__((packed)) ID {
00073                         uint32_t _value;
00074                         uint8_t  _v[4];
00075                         typename IDStruct::parts parts;
00076                         typename IDStruct::parts_ccp parts_ccp;
00077 
00079                         uint16_t etag() {
00080                             return parts._etag;
00081                         }
00082 
00084                         void etag(uint16_t e) {
00085                             parts._etag = e;
00086                         }
00087 
00089                         uint8_t tx_node() {
00090                             return parts._tx_nodelo | (parts._tx_nodehi << 2) ;
00091                         }
00092 
00094                         void tx_node(uint8_t t) {
00095                             parts._tx_nodelo = t & 0x3;
00096                             parts._tx_nodehi = t >> 2 ;
00097                         }
00098 
00102                         bool fragment() {
00103                             return parts._fragment;
00104                         }
00105 
00109                         void fragment(bool f) {
00110                             parts._fragment = f;
00111                         }
00112 
00114                         uint8_t prio() {
00115                             return parts._priolo | (parts._priohi << 2) ;
00116                         }
00117 
00119                         void prio(uint8_t p) {
00120                             parts._priolo = p & 0x7;
00121                             parts._priohi = p >> 2;
00122                         }
00123 
00125                         uint8_t ccp_stage() {
00126                             return parts_ccp._stage;
00127                         }
00128 
00130                         void ccp_stage(uint8_t stage) {
00131                             parts_ccp._stage = stage;
00132                         }
00133 
00135                         uint8_t ccp_nibble() {
00136                             return parts_ccp._nibblelo | (parts_ccp._nibblehi << 2) ;
00137                         }
00138 
00140                         void ccp_nibble(uint8_t nibble) {
00141                             parts_ccp._nibblelo = nibble;
00142                             parts_ccp._nibblehi = nibble >> 2;
00143                         }
00144 
00146                         uint8_t & operator[](uint8_t i) {
00147                             return _v[i];
00148                         }
00149                     };
00150 
00151                  } /* namespace detail */
00152 
00153             } /* namespace CAN */
00154         } /* namespace nl */
00155     } /* namespace mw */
00156 } /* namespace famouso */
00157 
00158 #endif