blob: 99b6a07332f0266d9b1747593a80a0a60f87e683 [file] [log] [blame]
The Android Open Source Project1dc9e472009-03-03 19:28:35 -08001/*
2 * Copyright (C) 2008 The Android Open Source Project
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in
12 * the documentation and/or other materials provided with the
13 * distribution.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
18 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
19 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
20 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
21 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
22 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
23 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
24 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
25 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 * SUCH DAMAGE.
27 */
Elliott Hughes203e13d2016-07-22 14:56:18 -070028
Elliott Hughesdd6763a2018-10-04 16:35:13 -070029#pragma once
30
31/**
32 * @file sys/param.h
33 * @brief Various macros.
34 */
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080035
Elliott Hughes414dd2d2024-10-16 14:48:30 +000036#include <sys/cdefs.h>
37
Elliott Hughes00dda092018-10-05 14:54:48 -070038#include <endian.h>
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080039#include <limits.h>
Yabin Cui2d8f9b52015-02-09 13:58:28 -080040#include <linux/param.h>
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080041
Elliott Hughesdd6763a2018-10-04 16:35:13 -070042/** The unit of `st_blocks` in `struct stat`. */
Elliott Hughes1f1a51a2016-03-31 17:05:30 -070043#define DEV_BSIZE 512
44
Elliott Hughese5bd2392024-04-09 16:48:18 +000045/** A historical name for PATH_MAX. Use PATH_MAX in new code. */
46#define MAXPATHLEN PATH_MAX
47
48/** A historical name for NGROUPS_MAX. Use NGROUPS_MAX in new code. */
49#define NGROUPS NGROUPS_MAX
Elliott Hughesdd6763a2018-10-04 16:35:13 -070050
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080051#define MAXSYMLINKS 8
52
Elliott Hughesc2f082f2013-12-12 15:31:35 -080053#ifndef howmany
54#define howmany(x, y) (((x)+((y)-1))/(y))
55#endif
56#define roundup(x, y) ((((x)+((y)-1))/(y))*(y))
Elliott Hughesc2f082f2013-12-12 15:31:35 -080057
Nick Kralevich3cfedf42019-03-27 10:20:06 -070058/**
Nick Kralevichc50b6a22019-03-21 14:04:33 -070059 * Returns true if the binary representation of the argument is all zeros
60 * or has exactly one bit set. Contrary to the macro name, this macro
61 * DOES NOT determine if the provided value is a power of 2. In particular,
62 * this function falsely returns true for powerof2(0) and some negative
63 * numbers.
64 */
Nick Kralevich3cfedf42019-03-27 10:20:06 -070065#define powerof2(x) \
66 ({ \
67 __typeof__(x) _x = (x); \
68 __typeof__(x) _x2; \
69 __builtin_add_overflow(_x, -1, &_x2) ? 1 : ((_x2 & _x) == 0); \
70 })
Elliott Hughesdd6763a2018-10-04 16:35:13 -070071
72/** Returns the lesser of its two arguments. */
Elliott Hughesc2f082f2013-12-12 15:31:35 -080073#define MIN(a,b) (((a)<(b))?(a):(b))
Elliott Hughesdd6763a2018-10-04 16:35:13 -070074/** Returns the greater of its two arguments. */
Elliott Hughesc2f082f2013-12-12 15:31:35 -080075#define MAX(a,b) (((a)>(b))?(a):(b))