-
Notifications
You must be signed in to change notification settings - Fork 154
/
byteorder.c
111 lines (93 loc) · 3.3 KB
/
byteorder.c
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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
/* byteorder.c -- convert 32 and 64-bit values between host and network byte order
*
* Copyright (c) 1994-2008 Carnegie Mellon University. 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 "Carnegie Mellon University" must not be used to
* endorse or promote products derived from this software without
* prior written permission. For permission or any legal
* details, please contact
* Carnegie Mellon University
* Center for Technology Transfer and Enterprise Creation
* 4615 Forbes Avenue
* Suite 302
* Pittsburgh, PA 15213
* (412) 268-7393, fax: (412) 268-7395
* innovation@andrew.cmu.edu
*
* 4. Redistributions of any form whatsoever must retain the following
* acknowledgment:
* "This product includes software developed by Computing Services
* at Carnegie Mellon University (http://www.cmu.edu/computing/)."
*
* CARNEGIE MELLON UNIVERSITY DISCLAIMS ALL WARRANTIES WITH REGARD TO
* THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
* AND FITNESS, IN NO EVENT SHALL CARNEGIE MELLON UNIVERSITY BE LIABLE
* FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN
* AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING
* OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
#include <config.h>
#include "byteorder.h"
#ifdef CYRUS_BYTESWAP
#include <netinet/in.h>
/* Structure used to swap the bytes in a 64-bit uint64_t. */
union byteswap_64_u {
uint64_t a;
uint32_t b[2];
};
/* Function to byteswap 64bit unsigned integers on
* little endian machines to big endian network order.
* On big endian machines this will be a null macro.
* The macro htonll() is defined in byteorder.h,
* and if needed refers to _htonll() here.
*/
EXPORTED uint64_t _htonll(uint64_t x)
{
union byteswap_64_u u1;
union byteswap_64_u u2;
u1.a = x;
u2.b[0] = htonl(u1.b[1]);
u2.b[1] = htonl(u1.b[0]);
return u2.a;
}
/* Function to byteswap big endian 64bit unsigned integers
* back to little endian host order on little endian machines.
* As above, on big endian machines this will be a null macro.
* The macro ntohll() is defined in byteorder.h, and if needed,
* refers to _ntohll() here.
*/
EXPORTED uint64_t _ntohll(uint64_t x)
{
union byteswap_64_u u1;
union byteswap_64_u u2;
u1.a = x;
u2.b[1] = ntohl(u1.b[0]);
u2.b[0] = ntohl(u1.b[1]);
return u2.a;
}
#endif /* CYRUS_BYTESWAP */
#include <string.h>
EXPORTED void *align_htonll(void *dst, uint64_t src)
{
uint64_t tmp = htonll(src);
return memcpy(dst, (void *) &tmp, sizeof(uint64_t));
}
EXPORTED uint64_t align_ntohll(const void *src)
{
uint64_t dst;
memcpy((void *) &dst, src, sizeof(uint64_t));
return ntohll(dst);
}