8748 loader: ptblread() is broken with >512B sectors
[unleashed.git] / usr / src / boot / sys / boot / common / util.c
blobd73d9921051eb9f196cb8783f9ede96770c47267
1 /*-
2 * Copyright (c) 1998 Robert Nordier
3 * Copyright (c) 2010 Pawel Jakub Dawidek <pjd@FreeBSD.org>
4 * All rights reserved.
6 * Redistribution and use in source and binary forms are freely
7 * permitted provided that the above copyright notice and this
8 * paragraph and the following disclaimer are duplicated in all
9 * such forms.
11 * This software is provided "AS IS" and without any express or
12 * implied warranties, including, without limitation, the implied
13 * warranties of merchantability and fitness for a particular
14 * purpose.
17 #include <sys/cdefs.h>
18 __FBSDID("$FreeBSD$");
20 #include <sys/param.h>
22 #include <stdarg.h>
24 #include "cons.h"
25 #include "util.h"
27 void
28 memcpy(void *dst, const void *src, int len)
30 const char *s = src;
31 char *d = dst;
33 while (len--)
34 *d++ = *s++;
37 void
38 memset(void *b, int c, size_t len)
40 char *bp = b;
42 while (len--)
43 *bp++ = (unsigned char)c;
46 int
47 memcmp(const void *b1, const void *b2, size_t len)
49 const unsigned char *p1, *p2;
51 for (p1 = b1, p2 = b2; len > 0; len--, p1++, p2++) {
52 if (*p1 != *p2)
53 return ((*p1) - (*p2));
55 return (0);
58 int
59 strcmp(const char *s1, const char *s2)
62 for (; *s1 == *s2 && *s1 != '\0'; s1++, s2++)
64 return ((unsigned char)*s1 - (unsigned char)*s2);
67 int
68 strncmp(const char *s1, const char *s2, size_t len)
71 for (; len > 0 && *s1 == *s2 && *s1 != '\0'; len--, s1++, s2++)
73 return (len == 0 ? 0 : (unsigned char)*s1 - (unsigned char)*s2);
76 void
77 strcpy(char *dst, const char *src)
80 while (*src != '\0')
81 *dst++ = *src++;
82 *dst = '\0';
85 void
86 strcat(char *dst, const char *src)
89 while (*dst != '\0')
90 dst++;
91 while (*src != '\0')
92 *dst++ = *src++;
93 *dst = '\0';
96 char *
97 strchr(const char *s, char ch)
100 for (; *s != '\0'; s++) {
101 if (*s == ch)
102 return ((char *)(uintptr_t)(const void *)s);
104 return (NULL);
107 size_t
108 strlen(const char *s)
110 size_t len = 0;
112 while (*s++ != '\0')
113 len++;
114 return (len);
118 printf(const char *fmt, ...)
120 va_list ap;
121 const char *hex = "0123456789abcdef";
122 char buf[32], *s;
123 uint16_t *S;
124 unsigned long long u;
125 int c, l;
127 va_start(ap, fmt);
128 while ((c = *fmt++) != '\0') {
129 if (c != '%') {
130 putchar(c);
131 continue;
133 l = 0;
134 nextfmt:
135 c = *fmt++;
136 switch (c) {
137 case 'l':
138 l++;
139 goto nextfmt;
140 case 'c':
141 putchar(va_arg(ap, int));
142 break;
143 case 's':
144 for (s = va_arg(ap, char *); *s != '\0'; s++)
145 putchar(*s);
146 break;
147 case 'S': /* Assume console can cope with wide chars */
148 for (S = va_arg(ap, uint16_t *); *S != 0; S++)
149 putchar(*S);
150 break;
151 case 'd': /* A lie, always prints unsigned */
152 case 'u':
153 case 'x':
154 switch (l) {
155 case 2:
156 u = va_arg(ap, unsigned long long);
157 break;
158 case 1:
159 u = va_arg(ap, unsigned long);
160 break;
161 default:
162 u = va_arg(ap, unsigned int);
163 break;
165 s = buf;
166 if (c == 'd' || c == 'u') {
168 *s++ = '0' + (u % 10U);
169 while (u /= 10);
170 } else {
172 *s++ = hex[u & 0xfu];
173 while (u >>= 4);
175 while (--s >= buf)
176 putchar(*s);
177 break;
180 va_end(ap);
181 return (0);