/* * CDDL HEADER START * * The contents of this file are subject to the terms of the * Common Development and Distribution License (the "License"). * You may not use this file except in compliance with the License. * * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE * or http://www.opensolaris.org/os/licensing. * See the License for the specific language governing permissions * and limitations under the License. * * When distributing Covered Code, include this CDDL HEADER in each * file and include the License file at usr/src/OPENSOLARIS.LICENSE. * If applicable, add the following below this CDDL HEADER, with the * fields enclosed by brackets "[]" replaced with your own identifying * information: Portions Copyright [yyyy] [name of copyright owner] * * CDDL HEADER END */ /* * Copyright 2008 Sun Microsystems, Inc. All rights reserved. * Use is subject to license terms. * Copyright (c) 2015, Joyent, Inc. */ .file "byteorder.s" #include /* * NOTE: htonll/ntohll, htonl/ntohl, and htons/ntohs are identical * routines. As such, they could be implemented as a single routine, * using multiple ALTENTRY/SET_SIZE definitions. We don't do this so * that they will have unique addresses, allowing DTrace and * other debuggers to tell them apart. */ /* * unsigned long long htonll( hll ) * unsigned long long ntohll( hll ) * unsigned long long hll; * reverses the byte order of 'uint64_t hll' on little endian machines */ ENTRY(htonll) movq %rdi, %rax /* %rax = hll */ bswapq %rax /* reverses the byte order of %rax */ ret /* return (%rax) */ SET_SIZE(htonll) ENTRY(ntohll) movq %rdi, %rax /* %rax = hll */ bswapq %rax /* reverses the byte order of %rax */ ret /* return (%rax) */ SET_SIZE(ntohll) /* * unsigned long htonl( hl ) * unsigned long ntohl( hl ) * unsigned long hl; * reverses the byte order of 'uint32_t hl' on little endian machines */ ENTRY(htonl) movl %edi, %eax /* %eax = hl */ bswap %eax /* reverses the byte order of %eax */ ret /* return (%eax) */ SET_SIZE(htonl) ENTRY(ntohl) movl %edi, %eax /* %eax = hl */ bswap %eax /* reverses the byte order of %eax */ ret /* return (%eax) */ SET_SIZE(ntohl) /* * unsigned short htons( hs ) * unsigned short hs; * reverses the byte order of 'uint16_t hs' on little endian machines. */ ENTRY(htons) movl %edi, %eax /* %eax = hs */ bswap %eax /* reverses the byte order of %eax */ shrl $16, %eax /* moves high 16-bit to low 16-bit */ ret /* return (%eax) */ SET_SIZE(htons) ENTRY(ntohs) movl %edi, %eax /* %eax = hs */ bswap %eax /* reverses the byte order of %eax */ shrl $16, %eax /* moves high 16-bit to low 16-bit */ ret /* return (%eax) */ SET_SIZE(ntohs) /* * uint16_t htobe16(uint16_t in); * uint32_t htobe32(uint32_t in); * uint64_t htobe64(uint64_t in); * * Byte swap 16, 32, and 64 bits respectively. * eg. htons(), htonl(), and htonll(). */ ENTRY(htobe16) movl %edi, %eax /* %eax = hs */ bswap %eax /* reverses the byte order of %eax */ shrl $16, %eax /* moves high 16-bit to low 16-bit */ ret /* return (%eax) */ SET_SIZE(htobe16) ENTRY(htobe32) movl %edi, %eax /* %eax = hl */ bswap %eax /* reverses the byte order of %eax */ ret /* return (%eax) */ SET_SIZE(htobe32) ENTRY(htobe64) movq %rdi, %rax /* %rax = hll */ bswapq %rax /* reverses the byte order of %rax */ ret /* return (%rax) */ SET_SIZE(htobe64) /* * uint16_t betoh16(uint16_t in) * uint16_t be16toh(uint16_t in) * * Convert in to little endian, eg. ntohs() */ ENTRY(betoh16) movl %edi, %eax /* %eax = hs */ bswap %eax /* reverses the byte order of %eax */ shrl $16, %eax /* moves high 16-bit to low 16-bit */ ret /* return (%eax) */ SET_SIZE(betoh16) ENTRY(be16toh) movl %edi, %eax /* %eax = hs */ bswap %eax /* reverses the byte order of %eax */ shrl $16, %eax /* moves high 16-bit to low 16-bit */ ret /* return (%eax) */ SET_SIZE(be16toh) /* * uint32_t betoh32(uint32_t in) * uint32_t be32toh(uint32_t in) * * Convert in to little endian, eg. ntohl() */ ENTRY(betoh32) movl %edi, %eax /* %eax = hl */ bswap %eax /* reverses the byte order of %eax */ ret /* return (%eax) */ SET_SIZE(betoh32) ENTRY(be32toh) movl %edi, %eax /* %eax = hl */ bswap %eax /* reverses the byte order of %eax */ ret /* return (%eax) */ SET_SIZE(be32toh) /* * uint64_t betoh64(uint64_t in) * uint64_t be64toh(uint64_t in) * * Convert in to little endian, eg. ntohll() */ ENTRY(betoh64) movq %rdi, %rax /* %rax = hll */ bswapq %rax /* reverses the byte order of %rax */ ret /* return (%rax) */ SET_SIZE(betoh64) ENTRY(be64toh) movq %rdi, %rax /* %rax = hll */ bswapq %rax /* reverses the byte order of %rax */ ret /* return (%rax) */ SET_SIZE(be64toh)