summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sbin/pdisk/file_media.c57
1 files changed, 17 insertions, 40 deletions
diff --git a/sbin/pdisk/file_media.c b/sbin/pdisk/file_media.c
index 94fc0abf7e2..e79e08b11e5 100644
--- a/sbin/pdisk/file_media.c
+++ b/sbin/pdisk/file_media.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: file_media.c,v 1.19 2016/01/13 00:12:49 krw Exp $ */
+/* $OpenBSD: file_media.c,v 1.20 2016/01/15 23:16:40 krw Exp $ */
/*
* file_media.c -
@@ -27,6 +27,9 @@
* WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
+#include <sys/param.h> /* DEV_BSIZE */
+#include <sys/dkio.h>
+#include <sys/disklabel.h>
#include <err.h>
// for printf()
@@ -83,7 +86,7 @@ static struct file_media_globals file_info;
/*
* Forward declarations
*/
-int compute_block_size(int fd);
+int compute_block_size(int fd, char *name);
void file_init(void);
FILE_MEDIA new_file_media(void);
long read_file_media(MEDIA m, long long offset, unsigned long count, void *address);
@@ -114,45 +117,19 @@ new_file_media(void)
int
-compute_block_size(int fd)
+compute_block_size(int fd, char *name)
{
- int size;
- int max_size;
- off_t x;
- long t;
- int i;
- char *buffer;
-
- max_size = 0;
- for (i = 0; ; i++) {
- size = potential_block_sizes[i];
- if (size == 0) {
- break;
- }
- if (max_size < size) {
- max_size = size;
- }
- }
+ struct disklabel dl;
+ struct stat st;
- buffer = malloc(max_size);
- if (buffer != 0) {
- for (i = 0; ; i++) {
- size = potential_block_sizes[i];
- if (size == 0) {
- break;
- }
- if ((x = lseek(fd, 0, SEEK_SET)) < 0) {
- warn("Can't seek on file");
- break;
- }
- if ((t = read(fd, buffer, size)) == size) {
- free(buffer);
- return size;
- }
- }
- }
- free(buffer);
- return 0;
+ if (fstat(fd, &st) == -1)
+ err(1, "can't fstat %s", name);
+ if (!S_ISCHR(st.st_mode) && !S_ISREG(st.st_mode))
+ errx(1, "%s is not a character device or a regular file", name);
+ if (ioctl(fd, DIOCGPDINFO, &dl) == -1)
+ err(1, "can't get disklabel for %s", name);
+
+ return (dl.d_secsize);
}
@@ -174,7 +151,7 @@ open_file_as_media(char *file, int oflag)
a = new_file_media();
if (a != 0) {
a->m.kind = file_info.kind;
- a->m.grain = compute_block_size(fd);
+ a->m.grain = compute_block_size(fd, file);
off = lseek(fd, 0, SEEK_END); /* seek to end of media */
//printf("file size = %Ld\n", off);
a->m.size_in_bytes = (long long) off;