~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/include/linux/packing.h

Version: ~ [ linux-6.11.5 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.58 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.114 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.169 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.228 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.284 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.322 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 /* SPDX-License-Identifier: BSD-3-Clause
  2  * Copyright 2016-2018 NXP
  3  * Copyright (c) 2018-2019, Vladimir Oltean <olteanv@gmail.com>
  4  */
  5 #ifndef _LINUX_PACKING_H
  6 #define _LINUX_PACKING_H
  7 
  8 #include <linux/types.h>
  9 #include <linux/bitops.h>
 10 
 11 #define QUIRK_MSB_ON_THE_RIGHT  BIT(0)
 12 #define QUIRK_LITTLE_ENDIAN     BIT(1)
 13 #define QUIRK_LSW32_IS_FIRST    BIT(2)
 14 
 15 enum packing_op {
 16         PACK,
 17         UNPACK,
 18 };
 19 
 20 /**
 21  * packing - Convert numbers (currently u64) between a packed and an unpacked
 22  *           format. Unpacked means laid out in memory in the CPU's native
 23  *           understanding of integers, while packed means anything else that
 24  *           requires translation.
 25  *
 26  * @pbuf: Pointer to a buffer holding the packed value.
 27  * @uval: Pointer to an u64 holding the unpacked value.
 28  * @startbit: The index (in logical notation, compensated for quirks) where
 29  *            the packed value starts within pbuf. Must be larger than, or
 30  *            equal to, endbit.
 31  * @endbit: The index (in logical notation, compensated for quirks) where
 32  *          the packed value ends within pbuf. Must be smaller than, or equal
 33  *          to, startbit.
 34  * @op: If PACK, then uval will be treated as const pointer and copied (packed)
 35  *      into pbuf, between startbit and endbit.
 36  *      If UNPACK, then pbuf will be treated as const pointer and the logical
 37  *      value between startbit and endbit will be copied (unpacked) to uval.
 38  * @quirks: A bit mask of QUIRK_LITTLE_ENDIAN, QUIRK_LSW32_IS_FIRST and
 39  *          QUIRK_MSB_ON_THE_RIGHT.
 40  *
 41  * Return: 0 on success, EINVAL or ERANGE if called incorrectly. Assuming
 42  *         correct usage, return code may be discarded.
 43  *         If op is PACK, pbuf is modified.
 44  *         If op is UNPACK, uval is modified.
 45  */
 46 int packing(void *pbuf, u64 *uval, int startbit, int endbit, size_t pbuflen,
 47             enum packing_op op, u8 quirks);
 48 
 49 #endif
 50 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php