From 1dd420957f9ba0e3991512a4627748bf38592d53 Mon Sep 17 00:00:00 2001 From: Sage Weil Date: Thu, 13 Nov 2008 16:48:15 -0800 Subject: journal: detect size of raw block devices properly --- src/os/FileJournal.cc | 23 ++++++++++++++++++++++- 1 file changed, 22 insertions(+), 1 deletion(-) diff --git a/src/os/FileJournal.cc b/src/os/FileJournal.cc index f9185e00a81..dce6a174531 100644 --- a/src/os/FileJournal.cc +++ b/src/os/FileJournal.cc @@ -18,6 +18,7 @@ #include #include #include +#include #include @@ -51,8 +52,28 @@ int FileJournal::_open(bool forwrite) assert(r == 0); max_size = st.st_size; block_size = st.st_blksize; + + if (max_size == 0) { + // hmm, is this a raw block device? +#ifdef BLKGETSIZE64 + // ioctl block device + uint64_t bytes; + r = ::ioctl(fd, BLKGETSIZE64, &bytes); + assert(r == 0); + max_size = bytes; +#else +# ifdef BLKGETSIZE + // hrm, try the 32 bit ioctl? + unsigned long sectors = 0; + r = ioctl(fd, BLKGETSIZE, §ors); + assert(r == 0); + max_size = sectors * 512ULL; +# endif +#endif + } + dout(2) << "_open " << fn << " fd " << fd - << ": " << st.st_size << " bytes, block size " << block_size << dendl; + << ": " << max_size << " bytes, block size " << block_size << dendl; return 0; } -- cgit v1.2.3