aboutsummaryrefslogtreecommitdiffstats
path: root/src/libcryptobox
diff options
context:
space:
mode:
Diffstat (limited to 'src/libcryptobox')
-rw-r--r--src/libcryptobox/base64/ref.c13
-rw-r--r--src/libcryptobox/base64/sse42.c13
2 files changed, 22 insertions, 4 deletions
diff --git a/src/libcryptobox/base64/ref.c b/src/libcryptobox/base64/ref.c
index 13e3b1040..2d757fe23 100644
--- a/src/libcryptobox/base64/ref.c
+++ b/src/libcryptobox/base64/ref.c
@@ -174,6 +174,9 @@ repeat:
break;
}
}
+ else {
+ leftover --;
+ }
/* If we get here, there was an error: */
break;
}
@@ -188,12 +191,18 @@ repeat:
break;
}
if ((q = base64_table_dec[*c++]) >= 254) {
- leftover = 0;
/*
* When q == 254, the input char is '='. Return 1 and EOF.
* When q == 255, the input char is invalid. Return 0 and EOF.
*/
- ret = ((q == 254) && (inlen == 0)) ? 1 : 0;
+ if (q == 254 && inlen == 0) {
+ ret = 1;
+ leftover = 0;
+ }
+ else {
+ ret = 0;
+ }
+
break;
}
diff --git a/src/libcryptobox/base64/sse42.c b/src/libcryptobox/base64/sse42.c
index ea5a6e1d6..12c6e3413 100644
--- a/src/libcryptobox/base64/sse42.c
+++ b/src/libcryptobox/base64/sse42.c
@@ -203,6 +203,9 @@ repeat:
break;
}
}
+ else {
+ leftover --;
+ }
/* If we get here, there was an error: */
break;
}
@@ -217,12 +220,18 @@ repeat:
break;
}
if ((q = base64_table_dec[*c++]) >= 254) {
- leftover = 0;
/*
* When q == 254, the input char is '='. Return 1 and EOF.
* When q == 255, the input char is invalid. Return 0 and EOF.
*/
- ret = ((q == 254) && (inlen == 0)) ? 1 : 0;
+ if (q == 254 && inlen == 0) {
+ ret = 1;
+ leftover = 0;
+ }
+ else {
+ ret = 0;
+ }
+
break;
}