summaryrefslogtreecommitdiffstats
path: root/include/linux/intel_th.h
diff options
context:
space:
mode:
authorIlya Dryomov <idryomov@gmail.com>2020-03-09 12:03:14 +0100
committerIlya Dryomov <idryomov@gmail.com>2020-03-23 13:07:08 +0100
commit7614209736fbc4927584d4387faade4f31444fce (patch)
treee0633bbfda62649ee23a10f993436275d8726451 /include/linux/intel_th.h
parent16fbf79b0f83bc752cee8589279f1ebfe57b3b6e (diff)
downloadlinux-7614209736fbc4927584d4387faade4f31444fce.tar.gz
linux-7614209736fbc4927584d4387faade4f31444fce.tar.bz2
linux-7614209736fbc4927584d4387faade4f31444fce.zip
ceph: check POOL_FLAG_FULL/NEARFULL in addition to OSDMAP_FULL/NEARFULL
CEPH_OSDMAP_FULL/NEARFULL aren't set since mimic, so we need to consult per-pool flags as well. Unfortunately the backwards compatibility here is lacking: - the change that deprecated OSDMAP_FULL/NEARFULL went into mimic, but was guarded by require_osd_release >= RELEASE_LUMINOUS - it was subsequently backported to luminous in v12.2.2, but that makes no difference to clients that only check OSDMAP_FULL/NEARFULL because require_osd_release is not client-facing -- it is for OSDs Since all kernels are affected, the best we can do here is just start checking both map flags and pool flags and send that to stable. These checks are best effort, so take osdc->lock and look up pool flags just once. Remove the FIXME, since filesystem quotas are checked above and RADOS quotas are reflected in POOL_FLAG_FULL: when the pool reaches its quota, both POOL_FLAG_FULL and POOL_FLAG_FULL_QUOTA are set. Cc: stable@vger.kernel.org Reported-by: Yanhu Cao <gmayyyha@gmail.com> Signed-off-by: Ilya Dryomov <idryomov@gmail.com> Reviewed-by: Jeff Layton <jlayton@kernel.org> Acked-by: Sage Weil <sage@redhat.com>
Diffstat (limited to 'include/linux/intel_th.h')
0 files changed, 0 insertions, 0 deletions