Files
fjrXTR f0ea57c2d7 S666LN-kernel: Initial Device kernel tree
* Based on S666LN-MA66BABCDEFLMNQ-T-OP-240322V1005
* Imported kernel-headers for dummy

Change-Id: I639796c449784d67edc65d7f38cf7d7119d117d2
Signed-off-by: fjrXTR <fajarslebew31@gmail.com>
2024-11-24 07:52:05 +01:00

33 lines
624 B
C

/* SPDX-License-Identifier: GPL-2.0 */
#ifndef _LINUX_BSEARCH_H
#define _LINUX_BSEARCH_H
#include <linux/types.h>
static __always_inline
void *__inline_bsearch(const void *key, const void *base, size_t num, size_t size, cmp_func_t cmp)
{
const char *pivot;
int result;
while (num > 0) {
pivot = base + (num >> 1) * size;
result = cmp(key, pivot);
if (result == 0)
return (void *)pivot;
if (result > 0) {
base = pivot + size;
num--;
}
num >>= 1;
}
return NULL;
}
extern void *bsearch(const void *key, const void *base, size_t num, size_t size, cmp_func_t cmp);
#endif /* _LINUX_BSEARCH_H */