Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 04 Mar 2010 10:17:58 -0700 (MST)
From:      "M. Warner Losh" <imp@bsdimp.com>
To:        c.jayachandran@gmail.com
Cc:        sobomax@FreeBSD.org, freebsd-current@FreeBSD.org
Subject:   Re: newfs failure on -current
Message-ID:  <20100304.101758.70320533242206105.imp@bsdimp.com>
In-Reply-To: <98a59be81003040504x6e97fbaeqeb10f8ea7bedb7b9@mail.gmail.com>
References:  <98a59be81003040504x6e97fbaeqeb10f8ea7bedb7b9@mail.gmail.com>

next in thread | previous in thread | raw e-mail | index | archive | help
In message: <98a59be81003040504x6e97fbaeqeb10f8ea7bedb7b9@mail.gmail.com>
            "C. Jayachandran" <c.jayachandran@gmail.com> writes:
: I'm testing this on the mips platform, but I think there is an issue
: with change that made sectorsize int64_t, because the ioctl
: DIOCGSECTORSIZE  used to read sector size seems to take u_int. This
: quick change fixes it for me (sample patch - may be whitespace
: damaged).
: 
: Index: sbin/newfs/newfs.c
: ===================================================================
: --- sbin/newfs/newfs.c  (revision 204687)
: +++ sbin/newfs/newfs.c  (working copy)
: @@ -327,9 +327,11 @@
:                 mediasize = st.st_size;
:                 /* set fssize from the partition */
:         } else {
: +           u_int tsize;
:             if (sectorsize == 0)
: -               if (ioctl(disk.d_fd, DIOCGSECTORSIZE, &sectorsize) == -1)
: +               if (ioctl(disk.d_fd, DIOCGSECTORSIZE, &tsize) == -1)
:                     sectorsize = 0;     /* back out on error for safety */
: +           sectorsize = tsize;
:             if (sectorsize && ioctl(disk.d_fd, DIOCGMEDIASIZE,
: &mediasize) != -1)
:                 getfssize(&fssize, special, mediasize / sectorsize, reserved);
:         }
: 

Maybe the right change is to back out the DIOCGSECTORSIZE change due
to silent breakage like this?

Warner



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20100304.101758.70320533242206105.imp>