diff --git a/stm/printf.c b/stm/printf.c
index 7bac07ab7257ebc0775ead1fa9f26d625a80d5d3..cfe4204b61d9db35c607b703e8487cb392b2aa5d 100644
--- a/stm/printf.c
+++ b/stm/printf.c
@@ -219,9 +219,19 @@ int pfenv_printf(const pfenv_t *pfenv, const char *fmt, va_list args) {
                 mp_float_t d = va_arg(args, double);
                 int left = (int)d;
                 int right = (int)((d - (mp_float_t)(int)d) * 1000000.0);
-                chrs += pfenv_print_int(pfenv, left, 1, 10, 'a', flags, width);
-                chrs += pfenv_print_strn(pfenv, &dot, 1, flags, width);
-                chrs += pfenv_print_int(pfenv, right, 0, 10, 'a', PF_FLAG_ZERO_PAD, 6);
+                if (right < 0) {
+                    if (left == 0) {
+                        chrs += pfenv_print_strn(pfenv, "-0", 2, flags, width);
+                    } else {
+                        chrs += pfenv_print_int(pfenv, left, 1, 10, 'a', flags, width); 
+                    }
+                    chrs += pfenv_print_strn(pfenv, &dot, 1, flags, width);
+                    chrs += pfenv_print_int(pfenv, -right, 0, 10, 'a', PF_FLAG_ZERO_PAD, 6);
+                } else {
+                    chrs += pfenv_print_int(pfenv, left, 1, 10, 'a', flags, width); 
+                    chrs += pfenv_print_strn(pfenv, &dot, 1, flags, width);
+                    chrs += pfenv_print_int(pfenv, right, 0, 10, 'a', PF_FLAG_ZERO_PAD, 6);
+                }
                 break;
             }
             default: