source: mainline/kernel/generic/include/bitops.h@ b60615bd

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since b60615bd was b60615bd, checked in by Jiří Zárevúcky <zarevucky.jiri@…>, 7 years ago

Modify kernel malloc()

This new implementation places the allocation size in front of the allocated
object, instead of relying on the slab allocator being able to determine source
slab cache for an object. This should improve scalability and help reduce
complexity of the memory management subsystem (further changes coming).

The drawback is more memory consumed by small malloc() allocations, however that
can be mitigated by switching to an API where the user provides known object
size to deallocation (most users know it either statically or from length they
necessarily remember).

  • Property mode set to 100644
File size: 2.4 KB
Line 
1/*
2 * Copyright (c) 2006 Ondrej Palkovsky
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 kernel_generic
30 * @{
31 */
32/** @file
33 */
34
35#ifndef KERN_BITOPS_H_
36#define KERN_BITOPS_H_
37
38#include <stdint.h>
39#include <trace.h>
40
41#ifdef __32_BITS__
42#define fnzb(arg) fnzb32(arg)
43#endif
44
45#ifdef __64_BITS__
46#define fnzb(arg) fnzb64(arg)
47#endif
48
49/** Return position of first non-zero bit from left (32b variant).
50 *
51 * @return 0 (if the number is zero) or [log_2(arg)].
52 *
53 */
54NO_TRACE static inline uint8_t fnzb32(uint32_t arg)
55{
56 uint8_t n = 0;
57
58 if (arg >> 16) {
59 arg >>= 16;
60 n += 16;
61 }
62
63 if (arg >> 8) {
64 arg >>= 8;
65 n += 8;
66 }
67
68 if (arg >> 4) {
69 arg >>= 4;
70 n += 4;
71 }
72
73 if (arg >> 2) {
74 arg >>= 2;
75 n += 2;
76 }
77
78 if (arg >> 1)
79 n += 1;
80
81 return n;
82}
83
84/** Return position of first non-zero bit from left (64b variant).
85 *
86 * @return 0 (if the number is zero) or [log_2(arg)].
87 *
88 */
89NO_TRACE static inline uint8_t fnzb64(uint64_t arg)
90{
91 uint8_t n = 0;
92
93 if (arg >> 32) {
94 arg >>= 32;
95 n += 32;
96 }
97
98 return n + fnzb32((uint32_t) arg);
99}
100
101#endif
102
103/** @}
104 */
Note: See TracBrowser for help on using the repository browser.