Apply rev #2 of dd fix from Gennady Feldman.
authorEric Andersen <andersen@codepoet.org>
Wed, 29 Nov 2000 22:33:02 +0000 (22:33 -0000)
committerEric Andersen <andersen@codepoet.org>
Wed, 29 Nov 2000 22:33:02 +0000 (22:33 -0000)
applets/usage.c
coreutils/dd.c
dd.c
usage.c

index a919a58f7dba2829cd7ff9eeed06e8ad339bf393..bab6d21b3001982b07d9dfd3f4052320ad173425 100644 (file)
@@ -161,7 +161,7 @@ const char dc_usage[] =
 
 #if defined BB_DD
 const char dd_usage[] =
-       "dd [if=FILE] [of=FILE] [bs=N] [count=N] [skip=N] [seek=N]\n"
+       "dd [if=FILE] [of=FILE] [bs=N] [count=N] [skip=N] [seek=N] [conv=notrunc|sync]\n"
 #ifndef BB_FEATURE_TRIVIAL_HELP
        "\nCopy a file, converting and formatting according to options\n\n"
        "\tif=FILE\tread from FILE instead of stdin\n"
@@ -171,6 +171,7 @@ const char dd_usage[] =
        "\tskip=N\tskip N input blocks\n"
        "\tseek=N\tskip N output blocks\n"
        "\tconv=notrunc\t dont truncate of at end of write\n"
+       "\tconv=sync\t pad the last block with zeros until blocksize\n"
        "\n"
        "Numbers may be suffixed by w (x2), k (x1024), b (x512), or M (x1024^2)\n"
 #endif
index 6868a913e811aa5e1b198eca2f80fa167e2419f4..2b77ea6a587a6882275f54310fa869eecd8f573f 100644 (file)
@@ -49,14 +49,15 @@ extern int dd_main(int argc, char **argv)
        int inCc = 0;
        int outCc;
        int trunc=TRUE;
-       long blockSize = 512;
+       int sync=FALSE;
+       long blockSize = 512,ibs;
        uintmax_t skipBlocks = 0;
        uintmax_t seekBlocks = 0;
        uintmax_t count = (uintmax_t) - 1;
        uintmax_t inTotal = 0;
        uintmax_t outTotal = 0;
        uintmax_t totalSize;
-       uintmax_t readSize;
+
        unsigned char buf[BUFSIZ];
        char *keyword = NULL;
 
@@ -98,6 +99,8 @@ extern int dd_main(int argc, char **argv)
                        keyword = (strchr(*argv, '=') + 1);
                        if (strcmp(keyword, "notrunc") == 0) 
                                trunc=FALSE;
+                       if (strcmp(keyword, "sync") == 0) 
+                               sync=TRUE;
                } else {
                        goto usage;
                }
@@ -137,13 +140,24 @@ extern int dd_main(int argc, char **argv)
        lseek(inFd, (off_t) (skipBlocks * blockSize), SEEK_SET);
        lseek(outFd, (off_t) (seekBlocks * blockSize), SEEK_SET);
        totalSize=count*blockSize;
-       while ((readSize = totalSize - inTotal) > 0) {
-               if (readSize > BUFSIZ)
-                       readSize=BUFSIZ;
-               inCc = fullRead(inFd, buf, readSize);
+
+       ibs=blockSize;
+       if (ibs > BUFSIZ)
+               ibs=BUFSIZ;
+                       
+       while (totalSize > outTotal) {
+               inCc = fullRead(inFd, buf, ibs);
                inTotal += inCc;
-               if ((outCc = fullWrite(outFd, buf, inCc)) < 1)
+               if ( (sync==TRUE) && (inCc>0) )
+                       while (inCc<ibs)
+                               buf[inCc++]='\0';
+
+               if ((outCc = fullWrite(outFd, buf, inCc)) < 1){
+                       if (outCc < 0 ){
+                               perror("Error during write");
+                       }
                        break;
+               }
                outTotal += outCc;
         }
        if (trunc == TRUE) {
diff --git a/dd.c b/dd.c
index 6868a913e811aa5e1b198eca2f80fa167e2419f4..2b77ea6a587a6882275f54310fa869eecd8f573f 100644 (file)
--- a/dd.c
+++ b/dd.c
@@ -49,14 +49,15 @@ extern int dd_main(int argc, char **argv)
        int inCc = 0;
        int outCc;
        int trunc=TRUE;
-       long blockSize = 512;
+       int sync=FALSE;
+       long blockSize = 512,ibs;
        uintmax_t skipBlocks = 0;
        uintmax_t seekBlocks = 0;
        uintmax_t count = (uintmax_t) - 1;
        uintmax_t inTotal = 0;
        uintmax_t outTotal = 0;
        uintmax_t totalSize;
-       uintmax_t readSize;
+
        unsigned char buf[BUFSIZ];
        char *keyword = NULL;
 
@@ -98,6 +99,8 @@ extern int dd_main(int argc, char **argv)
                        keyword = (strchr(*argv, '=') + 1);
                        if (strcmp(keyword, "notrunc") == 0) 
                                trunc=FALSE;
+                       if (strcmp(keyword, "sync") == 0) 
+                               sync=TRUE;
                } else {
                        goto usage;
                }
@@ -137,13 +140,24 @@ extern int dd_main(int argc, char **argv)
        lseek(inFd, (off_t) (skipBlocks * blockSize), SEEK_SET);
        lseek(outFd, (off_t) (seekBlocks * blockSize), SEEK_SET);
        totalSize=count*blockSize;
-       while ((readSize = totalSize - inTotal) > 0) {
-               if (readSize > BUFSIZ)
-                       readSize=BUFSIZ;
-               inCc = fullRead(inFd, buf, readSize);
+
+       ibs=blockSize;
+       if (ibs > BUFSIZ)
+               ibs=BUFSIZ;
+                       
+       while (totalSize > outTotal) {
+               inCc = fullRead(inFd, buf, ibs);
                inTotal += inCc;
-               if ((outCc = fullWrite(outFd, buf, inCc)) < 1)
+               if ( (sync==TRUE) && (inCc>0) )
+                       while (inCc<ibs)
+                               buf[inCc++]='\0';
+
+               if ((outCc = fullWrite(outFd, buf, inCc)) < 1){
+                       if (outCc < 0 ){
+                               perror("Error during write");
+                       }
                        break;
+               }
                outTotal += outCc;
         }
        if (trunc == TRUE) {
diff --git a/usage.c b/usage.c
index a919a58f7dba2829cd7ff9eeed06e8ad339bf393..bab6d21b3001982b07d9dfd3f4052320ad173425 100644 (file)
--- a/usage.c
+++ b/usage.c
@@ -161,7 +161,7 @@ const char dc_usage[] =
 
 #if defined BB_DD
 const char dd_usage[] =
-       "dd [if=FILE] [of=FILE] [bs=N] [count=N] [skip=N] [seek=N]\n"
+       "dd [if=FILE] [of=FILE] [bs=N] [count=N] [skip=N] [seek=N] [conv=notrunc|sync]\n"
 #ifndef BB_FEATURE_TRIVIAL_HELP
        "\nCopy a file, converting and formatting according to options\n\n"
        "\tif=FILE\tread from FILE instead of stdin\n"
@@ -171,6 +171,7 @@ const char dd_usage[] =
        "\tskip=N\tskip N input blocks\n"
        "\tseek=N\tskip N output blocks\n"
        "\tconv=notrunc\t dont truncate of at end of write\n"
+       "\tconv=sync\t pad the last block with zeros until blocksize\n"
        "\n"
        "Numbers may be suffixed by w (x2), k (x1024), b (x512), or M (x1024^2)\n"
 #endif