pg_restore: fix bogosity - Mailing list pgsql-patches

From Neil Conway
Subject pg_restore: fix bogosity
Date
Msg-id 42B776E6.6040202@samurai.com
Whole thread Raw
Responses Re: pg_restore: fix bogosity
List pgsql-patches
The Coverity tool picked up some rather bizarre code in _tarGetHeader in
pg_backup_tar.c:

(1) The code doesn't initialize `sum', so the initial "does the checksum
match?" test is wrong.

(2) The loop that is intended to check for a "null block" just checks
the first byte of the tar block 512 times, rather than each of the 512
bytes one time (!), which I'm guessing was the intent.

Attached is a patch that I believe should implement what the author
intended. Barring any objections, I'll apply this to HEAD and back
branches today or tomorrow.

-Neil
Index: src/bin/pg_dump/pg_backup_tar.c
===================================================================
RCS file: /var/lib/cvs/pgsql/src/bin/pg_dump/pg_backup_tar.c,v
retrieving revision 1.47
diff -c -r1.47 pg_backup_tar.c
*** src/bin/pg_dump/pg_backup_tar.c    25 Jan 2005 22:44:31 -0000    1.47
--- src/bin/pg_dump/pg_backup_tar.c    20 Jun 2005 01:44:37 -0000
***************
*** 1155,1161 ****
      size_t        len;
      unsigned long ullen;
      off_t        hPos;
-     int            i;
      bool        gotBlock = false;

      while (!gotBlock)
--- 1155,1160 ----
***************
*** 1178,1184 ****
          hPos = ctx->tarFHpos;

          /* Read a 512 byte block, return EOF, exit if short */
!         len = _tarReadRaw(AH, &h[0], 512, NULL, ctx->tarFH);
          if (len == 0)            /* EOF */
              return 0;

--- 1177,1183 ----
          hPos = ctx->tarFHpos;

          /* Read a 512 byte block, return EOF, exit if short */
!         len = _tarReadRaw(AH, h, 512, NULL, ctx->tarFH);
          if (len == 0)            /* EOF */
              return 0;

***************
*** 1188,1207 ****
                           (unsigned long) len);

          /* Calc checksum */
!         chk = _tarChecksum(&h[0]);

          /*
!          * If the checksum failed, see if it is a null block. If so, then
!          * just try with next block...
           */
-
          if (chk == sum)
              gotBlock = true;
          else
          {
              for (i = 0; i < 512; i++)
              {
!                 if (h[0] != 0)
                  {
                      gotBlock = true;
                      break;
--- 1187,1208 ----
                           (unsigned long) len);

          /* Calc checksum */
!         chk = _tarChecksum(h);
!         sscanf(&h[148], "%8o", &sum);

          /*
!          * If the checksum failed, see if it is a null block. If so,
!          * silently continue to the next block.
           */
          if (chk == sum)
              gotBlock = true;
          else
          {
+             int            i;
+
              for (i = 0; i < 512; i++)
              {
!                 if (h[i] != 0)
                  {
                      gotBlock = true;
                      break;
***************
*** 1213,1219 ****
      sscanf(&h[0], "%99s", tag);
      sscanf(&h[124], "%12lo", &ullen);
      len = (size_t) ullen;
-     sscanf(&h[148], "%8o", &sum);

      {
          char        buf[100];
--- 1214,1219 ----

pgsql-patches by date:

Previous
From: Neil Conway
Date:
Subject: Re: code cleanup for tz
Next
From: Bruce Momjian
Date:
Subject: Re: code cleanup for tz