]> git.apps.os.sepia.ceph.com Git - ceph.git/commitdiff
client: do not check file size when inode does not have Fc caps
authorVenky Shankar <vshankar@redhat.com>
Tue, 20 May 2025 12:19:41 +0000 (12:19 +0000)
committerVenky Shankar <vshankar@redhat.com>
Mon, 23 Jun 2025 03:19:03 +0000 (03:19 +0000)
Since the client is holding Fr caps, the read request can be
directly sent to the OSD. The offset/in->size comparison check
is causing the read request to return with no data since in->size
isn't yet updated when another client does an extending write.

Introduced-by: 942474c2f5b4c696364f3b7411ae7d96444edfa8
Fixes: http://tracker.ceph.com/issues/70726
Signed-off-by: Venky Shankar <vshankar@redhat.com>
(cherry picked from commit 2b74598afc52d1a6cb98ef6b524ec162360cf040)

src/client/Client.cc

index 889950d4a389f29bccbf492a56259d96130211a9..9e08aa1befa488530eb0bde086d43cbb4c3bc691 100644 (file)
@@ -11156,10 +11156,9 @@ retry:
     // C_Read_Sync_NonBlocking::finish().
 
     // trim read based on file size?
-    if (std::cmp_greater_equal(offset, in->size) || (size == 0)) {
-      // read is requested at the EOF or the read len is zero, therefore just
-      // release managed pointers and complete the C_Read_Finisher immediately with 0 bytes
-
+    if (size == 0) {
+      // zero byte read requested -- therefore just release managed
+      // pointers and complete the C_Read_Finisher immediately with 0 bytes
       Context *iof = iofinish.release();
       crf.release();
       iof->complete(0);