bswap
BSWAP(3) Linux Programmer's Manual BSWAP(3)
NAME
bswap_16, bswap_32, bswap_64 - reverse order of bytes
SYNOPSIS
#include <byteswap.h>
bswap_16(x);
bswap_32(x);
bswap_64(x);
DESCRIPTION
These macros return a value in which the order of the bytes in their
2-, 4-, or 8-byte arguments is reversed.
RETURN VALUE
These macros return the value of their argument with the bytes re-
versed.
ERRORS
These macros always succeed.
CONFORMING TO
These macros are GNU extensions.
EXAMPLE
The program below swaps the bytes of the 8-byte integer supplied as its
command-line argument. The following shell session demonstrates the
use of the program:
$ ./a.out 0x0123456789abcdef
0x123456789abcdef ==> 0xefcdab8967452301
Program source
#include <stdio.h>
#include <stdint.h>
#include <stdlib.h>
#include <inttypes.h>
#include <byteswap.h>
int
main(int argc, char *argv[])
{
uint64_t x;
if (argc != 2) {
fprintf(stderr, "Usage: %s <num>\n", argv[0]);
exit(EXIT_FAILURE);
}
x = strtoul(argv[1], NULL, 0);
printf("0x%" PRIx64 " ==> 0x%" PRIx64 "\n", x, bswap_64(x));
exit(EXIT_SUCCESS);
}
SEE ALSO
byteorder(3), endian(3)
COLOPHON
This page is part of release 5.05 of the Linux man-pages project. A
description of the project, information about reporting bugs, and the
latest version of this page, can be found at
https://www.kernel.org/doc/man-pages/.
Linux 2019-03-06 BSWAP(3)
Man Pages Copyright Respective Owners. Site Copyright (C) 1994 - 2025
Hurricane Electric.
All Rights Reserved.