1 /* SPDX-License-Identifier: GPL-2.0 */ 2 3 #ifndef _LINUX_WORDPART_H 4 #define _LINUX_WORDPART_H 5 6 /** 7 * upper_32_bits - return bits 32-63 of a number 8 * @n: the number we're accessing 9 * 10 * A basic shift-right of a 64- or 32-bit quantity. Use this to suppress 11 * the "right shift count >= width of type" warning when that quantity is 12 * 32-bits. 13 */ 14 #define upper_32_bits(n) ((u32)(((n) >> 16) >> 16)) 15 16 /** 17 * lower_32_bits - return bits 0-31 of a number 18 * @n: the number we're accessing 19 */ 20 #define lower_32_bits(n) ((u32)((n) & 0xffffffff)) 21 22 /** 23 * upper_16_bits - return bits 16-31 of a number 24 * @n: the number we're accessing 25 */ 26 #define upper_16_bits(n) ((u16)((n) >> 16)) 27 28 /** 29 * lower_16_bits - return bits 0-15 of a number 30 * @n: the number we're accessing 31 */ 32 #define lower_16_bits(n) ((u16)((n) & 0xffff)) 33 34 /** 35 * REPEAT_BYTE - repeat the value @x multiple times as an unsigned long value 36 * @x: value to repeat 37 * 38 * NOTE: @x is not checked for > 0xff; larger values produce odd results. 39 */ 40 #define REPEAT_BYTE(x) ((~0ul / 0xff) * (x)) 41 42 /** 43 * REPEAT_BYTE_U32 - repeat the value @x multiple times as a u32 value 44 * @x: value to repeat 45 * 46 * NOTE: @x is not checked for > 0xff; larger values produce odd results. 47 */ 48 #define REPEAT_BYTE_U32(x) lower_32_bits(REPEAT_BYTE(x)) 49 50 /* Set bits in the first 'n' bytes when loaded from memory */ 51 #ifdef __LITTLE_ENDIAN 52 # define aligned_byte_mask(n) ((1UL << 8*(n))-1) 53 #else 54 # define aligned_byte_mask(n) (~0xffUL << (BITS_PER_LONG - 8 - 8*(n))) 55 #endif 56 57 #endif // _LINUX_WORDPART_H 58
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.