You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

пре 19 година
пре 19 година
пре 19 година
пре 19 година
пре 18 година
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400
  1. /*
  2. * libcucul Canvas for ultrafast compositing of Unicode letters
  3. * libcaca Colour ASCII-Art library
  4. * Copyright (c) 2006 Sam Hocevar <sam@zoy.org>
  5. * 2006 Jean-Yves Lamoureux <jylam@lnxscene.org>
  6. * All Rights Reserved
  7. *
  8. * $Id$
  9. *
  10. * This library is free software. It comes without any warranty, to
  11. * the extent permitted by applicable law. You can redistribute it
  12. * and/or modify it under the terms of the Do What The Fuck You Want
  13. * To Public License, Version 2, as published by Sam Hocevar. See
  14. * http://sam.zoy.org/wtfpl/COPYING for more details.
  15. */
  16. /*
  17. * This file contains replacement functions for the standard C library
  18. * that must be used when building libcucul and libcaca into a kernel.
  19. */
  20. #include "config.h"
  21. #include "common.h"
  22. #ifdef __KERNEL__
  23. #define IS_DIGIT(x) (x>='0' && x<='9')
  24. #define IS_ALPHA(x) (x>='A' && x<='z')
  25. #define IS_UPPER(x) (x>='A' && x<='Z')
  26. #define IS_LOWER(x) (x>='a' && x<='z')
  27. #define UPPER(x) (IS_LOWER(x)?(x+('A'-'a')):x)
  28. #define LOWER(x) (IS_UPPER(x)?(x-('a'-'A')):x)
  29. /* Our default seed for random number generator */
  30. static int seed = 0x68743284;
  31. /* Our memory mapping */
  32. static uint32_t *freemem = (uint32_t*) 0x00200000;
  33. /* Multiboot kernel entry point */
  34. void cmain(unsigned long int magic, unsigned long int addr)
  35. {
  36. static char const text[] = "Booting libcaca kernel...";
  37. char const *ptr = text;
  38. char *video = (char*)0xB8000;
  39. char *argv[] = { NULL };
  40. int argc = 0;
  41. /* Print a text message to say hello */
  42. while(*ptr)
  43. *video = *ptr++; video += 2;
  44. /* Launch the main program */
  45. main(argc, argv);
  46. }
  47. /* stdlib.h functions */
  48. void *malloc(size_t size)
  49. {
  50. uint32_t *p = freemem;
  51. if(!size)
  52. return NULL;
  53. size = (size + 0x7) / 4;
  54. *p = size;
  55. freemem += size + 1;
  56. return p + 1;
  57. }
  58. void free(void *ptr)
  59. {
  60. return;
  61. }
  62. void *realloc(void *ptr, size_t size)
  63. {
  64. uint32_t oldsize;
  65. void *p;
  66. if(!size)
  67. return NULL;
  68. if(!ptr)
  69. oldsize = 0;
  70. else
  71. {
  72. oldsize = ((uint32_t *)ptr)[-1];
  73. if(oldsize >= size)
  74. return ptr;
  75. }
  76. p = malloc(size);
  77. memcpy(p, ptr, oldsize);
  78. return p;
  79. }
  80. char *getenv(const char *name)
  81. {
  82. return NULL;
  83. }
  84. int getpid(void)
  85. {
  86. return 0x1337;
  87. }
  88. void srand(unsigned int s)
  89. {
  90. seed = rand();
  91. }
  92. int time(void *dummy)
  93. {
  94. return rand();
  95. }
  96. int rand(void)
  97. {
  98. seed = (seed * 0x7f32ba17) ^ 0xf893a735;
  99. return seed % RAND_MAX;
  100. }
  101. int abs(int j)
  102. {
  103. if(j < 0)
  104. return -j;
  105. return j;
  106. }
  107. void exit(int status)
  108. {
  109. /* FIXME: reboot? */
  110. while(1);
  111. }
  112. /* string.h functions */
  113. void *memset(void *s, int c, size_t n)
  114. {
  115. uint8_t *ptr = s;
  116. while(n--)
  117. *ptr++ = c;
  118. return s;
  119. }
  120. void *memcpy(void *dest, const void *src, size_t n)
  121. {
  122. uint8_t *destptr = dest;
  123. uint8_t const *srcptr = src;
  124. while(n--)
  125. *destptr++ = *srcptr++;
  126. return dest;
  127. }
  128. size_t strlen(const char *s)
  129. {
  130. int len = 0;
  131. while(*s++)
  132. len++;
  133. return len;
  134. }
  135. int strcmp(const char *s1, const char *s2)
  136. {
  137. while(*s1 && *s1 == *s2)
  138. {
  139. s1++;
  140. s2++;
  141. }
  142. return (int)*s1 - (int)*s2;
  143. }
  144. int strcasecmp(const char *s1, const char *s2)
  145. {
  146. while(*s1 && *s2 && UPPER(*s1) == UPPER(*s2))
  147. {
  148. s1++;
  149. s2++;
  150. }
  151. return (int)UPPER(*s1) - (int)UPPER(*s2);
  152. }
  153. int memcmp(const void *_s1, const void *_s2, size_t n)
  154. {
  155. unsigned char const *s1 = _s1, *s2 = _s2;
  156. while(n--)
  157. {
  158. if(*s1 != *s2)
  159. return (int)*s1 - (int)*s2;
  160. s1++;
  161. s2++;
  162. }
  163. return 0;
  164. }
  165. char *strdup(const char *s)
  166. {
  167. char *new;
  168. unsigned int len = strlen(s);
  169. new = malloc(len + 1);
  170. memcpy(new, s, len + 1);
  171. return new;
  172. }
  173. char *strchr(const char *s, int c)
  174. {
  175. do
  176. if(*s == c)
  177. return (char *)(intptr_t)s;
  178. while(*s++);
  179. return NULL;
  180. }
  181. /* stdarg.h functions */
  182. int vsnprintf(char *str, size_t size, const char *format, va_list ap)
  183. {
  184. /* FIXME */
  185. return 0;
  186. }
  187. /* stdio.h functions */
  188. FILE *fopen(const char *path, const char *mode)
  189. {
  190. /* FIXME */
  191. return NULL;
  192. }
  193. int feof(FILE *stream)
  194. {
  195. /* FIXME */
  196. return 0;
  197. }
  198. char *fgets(char *s, int size, FILE *stream)
  199. {
  200. /* FIXME */
  201. return NULL;
  202. }
  203. size_t fwrite(const void *ptr, size_t size, size_t nmemb, FILE *stream)
  204. {
  205. return 0;
  206. }
  207. int fclose(FILE *fp)
  208. {
  209. /* FIXME */
  210. return 0;
  211. }
  212. int printf(const char *format, ...)
  213. {
  214. /* FIXME */
  215. return 0;
  216. }
  217. int fprintf(FILE *stream, const char *format, ...)
  218. {
  219. /* FIXME */
  220. return 0;
  221. }
  222. int fflush(FILE *stream)
  223. {
  224. /* FIXME */
  225. return 0;
  226. }
  227. int sprintf(char *str, const char *format, ...)
  228. {
  229. /* FIXME */
  230. return 0;
  231. }
  232. int sscanf(const char *str, const char *format, ...)
  233. {
  234. /* FIXME */
  235. return 0;
  236. }
  237. /* unistd.h functions */
  238. void usleep(unsigned long usec)
  239. {
  240. /* FIXME */
  241. return;
  242. }
  243. /* time.h functions */
  244. int gettimeofday(struct timeval *tv, struct timezone *tz)
  245. {
  246. static int usec = 0;
  247. static int sec = 0;
  248. /* FIXME */
  249. usec += 10000;
  250. if(usec > 1000000)
  251. {
  252. sec++;
  253. usec -= 1000000;
  254. }
  255. tv->tv_sec = sec;
  256. tv->tv_usec = usec;
  257. return 0;
  258. }
  259. /* math.h functions */
  260. double cos(double x)
  261. {
  262. double ret = 0.0;
  263. #ifdef HAVE_FSIN_FCOS
  264. asm volatile("fcos" : "=t" (ret) : "0" (x));
  265. #else
  266. double x2;
  267. double num = 1.0;
  268. double fact = 1.0;
  269. int i;
  270. x = x - ((double)(int)(x / (2 * M_PI))) * (2 * M_PI);
  271. x2 = x * x;
  272. /* cos(x) = 1/0! - x^2/2! + x^4/4! - x^6/6! ... */
  273. for(i = 0; i < 10; i++)
  274. {
  275. ret += num / fact;
  276. num *= - x2;
  277. fact *= (2 * i + 1) * (2 * i + 2);
  278. }
  279. #endif
  280. return ret;
  281. }
  282. double sin(double x)
  283. {
  284. double ret = 0.0;
  285. #ifdef HAVE_FSIN_FCOS
  286. asm volatile("fsin" : "=t" (ret) : "0" (x));
  287. #else
  288. double x2;
  289. double num;
  290. double fact = 1.0;
  291. int i;
  292. x = x - ((double)(int)(x / (2 * M_PI))) * (2 * M_PI);
  293. x2 = x * x;
  294. num = x;
  295. /* sin(x) = x/1! - x^3/3! + x^5/5! - x^7/7! ... */
  296. for(i = 0; i < 10; i++)
  297. {
  298. ret += num / fact;
  299. num *= - x2;
  300. fact *= (2 * i + 2) * (2 * i + 3);
  301. }
  302. #endif
  303. return ret;
  304. }
  305. double sqrt(double x)
  306. {
  307. double ret = x;
  308. int i;
  309. /* This is Newton's method */
  310. for(i = 0; i < 10; i++)
  311. ret = (ret * ret + x) / (ret * 2.0);
  312. return ret;
  313. }
  314. /* errno.h stuff */
  315. int errno = 0;
  316. /* arpa/inet.h functions */
  317. /* XXX FIXME Converts only from little endian to big endian (x86) */
  318. unsigned int htonl(unsigned int hostlong)
  319. {
  320. return ((hostlong&0xFFFF0000)>>16)|((hostlong&0x0000FFFFFF)<<16);
  321. }
  322. /* XXX FIXME Converts only from little endian to big endian (x86) */
  323. unsigned short htons(unsigned short hostlong)
  324. {
  325. return ((hostlong&0xFF00)>>8)|((hostlong&0x00FF)<<8);
  326. }
  327. #endif /* __KERNEL__ */