blob: 1c991aefc1144206f71ca5a47b0998c301be88ac [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 Hughes00dda092018-10-05 14:54:48 -070036#include <endian.h>
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080037#include <limits.h>
Yabin Cui2d8f9b52015-02-09 13:58:28 -080038#include <linux/param.h>
Elliott Hughes203e13d2016-07-22 14:56:18 -070039#include <sys/cdefs.h>
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080040
Elliott Hughesdd6763a2018-10-04 16:35:13 -070041/** The unit of `st_blocks` in `struct stat`. */
Elliott Hughes1f1a51a2016-03-31 17:05:30 -070042#define DEV_BSIZE 512
43
Elliott Hughese5bd2392024-04-09 16:48:18 +000044/** A historical name for PATH_MAX. Use PATH_MAX in new code. */
45#define MAXPATHLEN PATH_MAX
46
47/** A historical name for NGROUPS_MAX. Use NGROUPS_MAX in new code. */
48#define NGROUPS NGROUPS_MAX
Elliott Hughesdd6763a2018-10-04 16:35:13 -070049
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080050#define MAXSYMLINKS 8
51
Elliott Hughesc2f082f2013-12-12 15:31:35 -080052#ifndef howmany
53#define howmany(x, y) (((x)+((y)-1))/(y))
54#endif
55#define roundup(x, y) ((((x)+((y)-1))/(y))*(y))
Elliott Hughesc2f082f2013-12-12 15:31:35 -080056
Nick Kralevich3cfedf42019-03-27 10:20:06 -070057/**
Nick Kralevichc50b6a22019-03-21 14:04:33 -070058 * Returns true if the binary representation of the argument is all zeros
59 * or has exactly one bit set. Contrary to the macro name, this macro
60 * DOES NOT determine if the provided value is a power of 2. In particular,
61 * this function falsely returns true for powerof2(0) and some negative
62 * numbers.
63 */
Nick Kralevich3cfedf42019-03-27 10:20:06 -070064#define powerof2(x) \
65 ({ \
66 __typeof__(x) _x = (x); \
67 __typeof__(x) _x2; \
68 __builtin_add_overflow(_x, -1, &_x2) ? 1 : ((_x2 & _x) == 0); \
69 })
Elliott Hughesdd6763a2018-10-04 16:35:13 -070070
71/** Returns the lesser of its two arguments. */
Elliott Hughesc2f082f2013-12-12 15:31:35 -080072#define MIN(a,b) (((a)<(b))?(a):(b))
Elliott Hughesdd6763a2018-10-04 16:35:13 -070073/** Returns the greater of its two arguments. */
Elliott Hughesc2f082f2013-12-12 15:31:35 -080074#define MAX(a,b) (((a)>(b))?(a):(b))