OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [ecos-3.0/] [packages/] [hal/] [common/] [current/] [include/] [hal_endian.h] - Blame information for rev 838

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 786 skrzyp
#ifndef CYGONCE_HAL_HAL_ENDIAN_H
2
#define CYGONCE_HAL_HAL_ENDIAN_H
3
 
4
//=============================================================================
5
//
6
//      hal_endian.h
7
//
8
//      Endian conversion macros
9
//
10
//=============================================================================
11
// ####ECOSGPLCOPYRIGHTBEGIN####                                            
12
// -------------------------------------------                              
13
// This file is part of eCos, the Embedded Configurable Operating System.   
14
// Copyright (C) 1998, 1999, 2000, 2001, 2002 Free Software Foundation, Inc.
15
//
16
// eCos is free software; you can redistribute it and/or modify it under    
17
// the terms of the GNU General Public License as published by the Free     
18
// Software Foundation; either version 2 or (at your option) any later      
19
// version.                                                                 
20
//
21
// eCos is distributed in the hope that it will be useful, but WITHOUT      
22
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or    
23
// FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License    
24
// for more details.                                                        
25
//
26
// You should have received a copy of the GNU General Public License        
27
// along with eCos; if not, write to the Free Software Foundation, Inc.,    
28
// 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.            
29
//
30
// As a special exception, if other files instantiate templates or use      
31
// macros or inline functions from this file, or you compile this file      
32
// and link it with other works to produce a work based on this file,       
33
// this file does not by itself cause the resulting work to be covered by   
34
// the GNU General Public License. However the source code for this file    
35
// must still be made available in accordance with section (3) of the GNU   
36
// General Public License v2.                                               
37
//
38
// This exception does not invalidate any other reasons why a work based    
39
// on this file might be covered by the GNU General Public License.         
40
// -------------------------------------------                              
41
// ####ECOSGPLCOPYRIGHTEND####                                              
42
//=============================================================================
43
//#####DESCRIPTIONBEGIN####
44
//
45
// Author(s):   jskov
46
// Contributors:jskov
47
// Date:        2001-10-04
48
// Purpose:     Endian conversion macros
49
// Usage:       #include <cyg/hal/hal_endian.h>
50
//                           
51
//####DESCRIPTIONEND####
52
//
53
//=============================================================================
54
 
55
#include <pkgconf/hal.h>                // CYGBLD_HAL_ENDIAN_H
56
#include <cyg/infra/cyg_type.h>         // endian setting
57
 
58
// Allow HALs to override the generic implementation of swap macros
59
#ifdef CYGBLD_HAL_ENDIAN_H
60
# include CYGBLD_HAL_ENDIAN_H
61
#endif
62
 
63
#ifndef CYG_SWAP16
64
# define CYG_SWAP16(_x_)                                        \
65
    ({ cyg_uint16 _x = (_x_); (cyg_uint16)((_x << 8) | (_x >> 8)); })
66
#endif
67
 
68
#ifndef CYG_SWAP32
69
# define CYG_SWAP32(_x_)                        \
70
    ({ cyg_uint32 _x = (_x_);                   \
71
       ((_x << 24) |                            \
72
       ((0x0000FF00UL & _x) <<  8) |            \
73
       ((0x00FF0000UL & _x) >>  8) |            \
74
       (_x  >> 24)); })
75
#endif
76
 
77
 
78
#if (CYG_BYTEORDER == CYG_LSBFIRST)
79
# define CYG_CPU_TO_BE16(_x_) CYG_SWAP16((_x_))
80
# define CYG_CPU_TO_BE32(_x_) CYG_SWAP32((_x_))
81
# define CYG_BE16_TO_CPU(_x_) CYG_SWAP16((_x_))
82
# define CYG_BE32_TO_CPU(_x_) CYG_SWAP32((_x_))
83
 
84
# define CYG_CPU_TO_LE16(_x_) (_x_)
85
# define CYG_CPU_TO_LE32(_x_) (_x_)
86
# define CYG_LE16_TO_CPU(_x_) (_x_)
87
# define CYG_LE32_TO_CPU(_x_) (_x_)
88
 
89
#elif (CYG_BYTEORDER == CYG_MSBFIRST)
90
 
91
# define CYG_CPU_TO_BE16(_x_) (_x_)
92
# define CYG_CPU_TO_BE32(_x_) (_x_)
93
# define CYG_BE16_TO_CPU(_x_) (_x_)
94
# define CYG_BE32_TO_CPU(_x_) (_x_)
95
 
96
# define CYG_CPU_TO_LE16(_x_) CYG_SWAP16((_x_))
97
# define CYG_CPU_TO_LE32(_x_) CYG_SWAP32((_x_))
98
# define CYG_LE16_TO_CPU(_x_) CYG_SWAP16((_x_))
99
# define CYG_LE32_TO_CPU(_x_) CYG_SWAP32((_x_))
100
 
101
#else
102
 
103
# error "Endian mode not selected"
104
 
105
#endif
106
 
107
//-----------------------------------------------------------------------------
108
#endif // CYGONCE_HAL_HAL_ENDIAN_H
109
// End of hal_endian.h

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.