source: mainline/kernel/generic/include/macros.h@ f9061b4

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since f9061b4 was 933cadf, checked in by Martin Decky <martin@…>, 15 years ago

use binary suffixes in printouts where appropriate

  • Property mode set to 100644
File size: 3.8 KB
Line 
1/*
2 * Copyright (c) 2005 Jakub Jermar
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 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29/** @addtogroup generic
30 * @{
31 */
32/** @file
33 */
34
35#ifndef KERN_MACROS_H_
36#define KERN_MACROS_H_
37
38#ifndef __ASM__
39
40#include <typedefs.h>
41#include <trace.h>
42
43/** Return true if the intervals overlap.
44 *
45 * @param s1 Start address of the first interval.
46 * @param sz1 Size of the first interval.
47 * @param s2 Start address of the second interval.
48 * @param sz2 Size of the second interval.
49 *
50 */
51NO_TRACE static inline int overlaps(uint64_t s1, uint64_t sz1, uint64_t s2,
52 uint64_t sz2)
53{
54 uint64_t e1 = s1 + sz1;
55 uint64_t e2 = s2 + sz2;
56
57 return ((s1 < e2) && (s2 < e1));
58}
59
60/** Return true if the second interval is within the first interval.
61 *
62 * @param s1 Start address of the first interval.
63 * @param sz1 Size of the first interval.
64 * @param s2 Start address of the second interval.
65 * @param sz2 Size of the second interval.
66 *
67 */
68NO_TRACE static inline int iswithin(uint64_t s1, uint64_t sz1, uint64_t s2,
69 uint64_t sz2)
70{
71 uint64_t e1 = s1 + sz1;
72 uint64_t e2 = s2 + sz2;
73
74 return ((s1 <= s2) && (e1 >= e2));
75}
76
77#endif /* __ASM__ */
78
79#define isdigit(d) (((d) >= '0') && ((d) <= '9'))
80#define islower(c) (((c) >= 'a') && ((c) <= 'z'))
81#define isupper(c) (((c) >= 'A') && ((c) <= 'Z'))
82#define isalpha(c) (is_lower((c)) || is_upper((c)))
83#define isalphanum(c) (is_alpha((c)) || is_digit((c)))
84#define isspace(c) \
85 (((c) == ' ') || ((c) == '\t') || ((c) == '\n') || ((c) == '\r'))
86
87#define min(a, b) ((a) < (b) ? (a) : (b))
88#define max(a, b) ((a) > (b) ? (a) : (b))
89
90#define min3(a, b, c) ((a) < (b) ? (min(a, c)) : (min(b, c)))
91#define max3(a, b, c) ((a) > (b) ? (max(a, c)) : (max(b, c)))
92
93/* Compute overlapping of physical addresses */
94#define PA_OVERLAPS(x, szx, y, szy) \
95 overlaps(KA2PA((x)), (szx), KA2PA((y)), (szy))
96
97#define KiB2SIZE(kb) ((kb) << 10)
98#define MiB2SIZE(mb) ((mb) << 20)
99
100#define STRING(arg) STRING_ARG(arg)
101#define STRING_ARG(arg) #arg
102
103#define LOWER32(arg) (((uint64_t) (arg)) & UINT32_C(0xffffffff))
104#define UPPER32(arg) (((((uint64_t) arg)) >> 32) & UINT32_C(0xffffffff))
105
106#define MERGE_LOUP32(lo, up) \
107 ((((uint64_t) (lo)) & UINT32_C(0xffffffff)) \
108 | ((((uint64_t) (up)) & UINT32_C(0xffffffff)) << 32))
109
110/** Pseudorandom generator
111 *
112 * A pretty standard linear congruential pseudorandom
113 * number generator (m = 2^32 or 2^64 depending on architecture).
114 *
115 */
116#define RANDI(seed) \
117 ({ \
118 (seed) = 1103515245 * (seed) + 12345; \
119 (seed); \
120 })
121
122#endif
123
124/** @}
125 */
Note: See TracBrowser for help on using the repository browser.