]> Joshua Wise's Git repositories - netwatch.git/blobdiff - lib/minilib.c
Wait for completion before we pull the trigger on the pbuf
[netwatch.git] / lib / minilib.c
index f64f3b1d7bf96469a533af0b3bf8198d2a969ea0..664a0b42a7abe24229793a7490fd5b5cc934a923 100644 (file)
@@ -1,26 +1,38 @@
 #include "console.h"
 #include "console.h"
+#include <minilib.h>
 
 
-void memcpy(unsigned char *a2, unsigned char *a1, int bytes)
+void memcpy(void *dest, const void *src, int bytes)
 {
 {
+       char *cdest = dest;
+       const char *csrc = src;
        while (bytes--)
        while (bytes--)
-               *(a2++) = *(a1++);
+               *(cdest++) = *(csrc++);
 }
 
 }
 
-void memmove(unsigned char *dest, unsigned char *src, int bytes)
+void memset(void *dest, int data, int bytes)
 {
 {
-       if ((dest > src) && (dest <= (src + bytes)))
+       unsigned char *cdest = dest;
+       while (bytes--)
+               *(cdest++) = (unsigned char)data;
+}
+
+void memmove(void *dest, void *src, int bytes)
+{
+       char * cdest = dest;
+       char * csrc = src;
+       if ((cdest > csrc) && (cdest <= (csrc + bytes)))
        {
                /* do it backwards! */
        {
                /* do it backwards! */
-               dest += bytes;
-               src += bytes;
+               cdest += bytes;
+               csrc += bytes;
                while (bytes--)
                while (bytes--)
-                       *(--dest) = *(--src);
+                       *(--cdest) = *(--csrc);
        } else
                while (bytes--)
        } else
                while (bytes--)
-                       *(dest++) = *(src++);
+                       *(cdest++) = *(csrc++);
 }
 
 }
 
-int memcmp (unsigned char *a2, unsigned char *a1, int bytes) {
+int memcmp (const char *a2, const char *a1, int bytes) {
        while (bytes--)
        {
                if (*(a2++) != *(a1++))
        while (bytes--)
        {
                if (*(a2++) != *(a1++))
@@ -29,7 +41,7 @@ int memcmp (unsigned char *a2, unsigned char *a1, int bytes) {
        return 0;
 }
 
        return 0;
 }
 
-int strcmp (unsigned char *a2, unsigned char *a1) {
+int strcmp (const char *a2, const char *a1) {
        while (1) {
                if (*a2 != *a1) return 1;
                if (*a2 == 0) return 0;
        while (1) {
                if (*a2 != *a1) return 1;
                if (*a2 == 0) return 0;
@@ -38,7 +50,17 @@ int strcmp (unsigned char *a2, unsigned char *a1) {
        }
 }
 
        }
 }
 
-int strlen(char *c)
+int strncmp (const char *a2, const char *a1, int n) {
+       while (n--) {
+               if (*a2 != *a1) return 1;
+               if (*a2 == 0) return 0;
+               a1++;
+               a2++;
+       }
+       return 0;
+}
+
+int strlen(const char *c)
 {
        int l = 0;
        while (*(c++))
 {
        int l = 0;
        while (*(c++))
@@ -46,20 +68,29 @@ int strlen(char *c)
        return l;
 }
 
        return l;
 }
 
-void strcpy(unsigned char *a2, unsigned char *a1)
+void strcpy(char *a2, const char *a1)
 {
        do {
                *(a2++) = *a1;
        } while (*(a1++));
 }
 
 {
        do {
                *(a2++) = *a1;
        } while (*(a1++));
 }
 
-void puts(char *c)
+void strcat(char *dest, char *src)
+{
+       while (*dest)
+               dest++;
+       while (*src)
+               *(dest++) = *(src++);
+       *(dest++) = *(src++);
+}
+
+void puts(const char *c)
 {
        putbytes(c, strlen(c));
 }
 
 static char hexarr[] = "0123456789ABCDEF";
 {
        putbytes(c, strlen(c));
 }
 
 static char hexarr[] = "0123456789ABCDEF";
-void tohex(unsigned char *s, unsigned long l)
+void tohex(char *s, unsigned long l)
 {
        int i;
        for (i = 0; i < 8; i++)
 {
        int i;
        for (i = 0; i < 8; i++)
@@ -71,10 +102,21 @@ void tohex(unsigned char *s, unsigned long l)
 
 void puthex(unsigned long l)
 {
 
 void puthex(unsigned long l)
 {
-       unsigned char d[9];
+       char d[9];
        d[8] = 0;
        tohex(d, l);
        puts(d);
 }
 
        d[8] = 0;
        tohex(d, l);
        puts(d);
 }
 
+unsigned short htons(unsigned short in)
+{
+       return (in >> 8) | (in << 8);
+}
 
 
+unsigned int htonl(unsigned int in)
+{
+       return ((in & 0xff) << 24) |
+              ((in & 0xff00) << 8) |
+              ((in & 0xff0000UL) >> 8) |
+              ((in & 0xff000000UL) >> 24);
+}
This page took 0.031108 seconds and 4 git commands to generate.