[go: up one dir, main page]

File: endian.h

package info (click to toggle)
srecord 1.64-1
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 5,652 kB
  • sloc: cpp: 29,491; sh: 8,116; makefile: 3,943; awk: 187; vhdl: 15
file content (75 lines) | stat: -rw-r--r-- 1,979 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
//
// srecord - Manipulate EPROM load files
// Copyright (C) 2008, 2010-2012 Peter Miller
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as published by
// the Free Software Foundation; either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with this program. If not, see
// <http://www.gnu.org/licenses/>.
//

#ifndef SRECORD_ENDIAN_H
#define SRECORD_ENDIAN_H

namespace srecord
{

enum endian_t
{
    endian_big,
    endian_little
};

/**
  * The endian_to_string function may be used to convert an endian value
  * into its string equivalent.
  *
  * @param x
  *     The value to convert
  * @returns
  *     a C string
  */
const char *endian_to_string(endian_t x);

/**
  * The decode_word_be function is used to decode a big-endian 2-byte
  * data buffer into an unsigned short value.
  *
  * @param data
  *     The data to be decoded
  */
unsigned short decode_word_be(const unsigned char *data);

/**
  * The decode_word_le function is used to decode a little-endian 2-byte
  * data buffer into an unsigned short value.
  *
  * @param data
  *     The data to be decoded
  */
unsigned short decode_word_le(const unsigned char *data);

/**
  * The decode_word_le function is used to decode a little-endian 2-byte
  * data buffer into an unsigned short value.
  *
  * @param data
  *     The data to be decoded
  * @param order
  *     The order of the bytes to be decoded.
  */
unsigned short endian_decode_word(const unsigned char *data, endian_t order);

};

// vim: set ts=8 sw=4 et :
#endif // SRECORD_ENDIAN_H