eprint don't need \n in the format
[pam_pcsc_cr.git] / serial.c
index 6bce59e8cf7b282a6718d4f6b2d9e6be09673223..809ea7ce108a41e0d0e942ce58980291870ea6b8 100644 (file)
--- a/serial.c
+++ b/serial.c
@@ -4,14 +4,13 @@
 #include <string.h>
 #include "serial.h"
 
-int serial_init(serializer_t *srl, void *buffer, int size)
+void serial_init(serializer_t *srl, void *buffer, int size)
 {
        srl->buffer = srl->cursor = buffer;
        srl->bufsize = size;
-       return 0;
 }
 
-int serial_switch(serializer_t *srl, void *buffer, int size)
+void serial_switch(serializer_t *srl, void *buffer, int size)
 {
        int used = srl->cursor - srl->buffer;
 
@@ -21,12 +20,13 @@ int serial_switch(serializer_t *srl, void *buffer, int size)
        srl->cursor = buffer + used;
 }
 
-int serial_put(serializer_t *srl, void *item, int size)
+int serial_put(serializer_t *srl, const void *item, int size)
 {
        int left = srl->bufsize - (srl->cursor - srl->buffer);
+
        if (left < size + sizeof(short)) return left - sizeof(short);
        *((short *)srl->cursor) = size;
-       srl->cursor += 2;
+       srl->cursor += sizeof(short);
        if (size) memcpy(srl->cursor, item, size);
        srl->cursor += size;
        return size;
@@ -34,10 +34,13 @@ int serial_put(serializer_t *srl, void *item, int size)
 
 int serial_get(serializer_t *srl, void *item, int bufsize)
 {
+       int left = srl->bufsize - (srl->cursor - srl->buffer);
        short isize = *((short *)srl->cursor);
-       if (isize > bufsize || isize == 0) return isize;
+
+       if (isize > bufsize) return isize;
+       if (isize + sizeof(short) > left) return -1;
        srl->cursor += sizeof(short);
-       memcpy(item, srl->cursor, isize);
+       if (isize) memcpy(item, srl->cursor, isize);
        srl->cursor += isize;
        return isize;
 }