Re: [PATCH 3/9] rbd: treat images mapped read-only seriously

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, Nov 19, 2019 at 9:37 AM Dongsheng Yang
<dongsheng.yang@xxxxxxxxxxxx> wrote:
>
>
>
> On 11/18/2019 09:38 PM, Ilya Dryomov wrote:
> > Even though -o ro/-o read_only/--read-only options are very old, we
> > have never really treated them seriously (on par with snapshots).  As
> > a first step, fail writes to images mapped read-only just like we do
> > for snapshots.
> >
> > We need this check in rbd because the block layer basically ignores
> > read-only setting, see commit a32e236eb93e ("Partially revert "block:
> > fail op_is_write() requests to read-only partitions"").
> >
> > Signed-off-by: Ilya Dryomov <idryomov@xxxxxxxxx>
> > ---
> >   drivers/block/rbd.c | 13 ++++++++-----
> >   1 file changed, 8 insertions(+), 5 deletions(-)
> >
> > diff --git a/drivers/block/rbd.c b/drivers/block/rbd.c
> > index 330d2789f373..842b92ef2c06 100644
> > --- a/drivers/block/rbd.c
> > +++ b/drivers/block/rbd.c
> > @@ -4820,11 +4820,14 @@ static void rbd_queue_workfn(struct work_struct *work)
> >               goto err_rq;
> >       }
> >
> > -     if (op_type != OBJ_OP_READ && rbd_is_snap(rbd_dev)) {
> > -             rbd_warn(rbd_dev, "%s on read-only snapshot",
> > -                      obj_op_name(op_type));
> > -             result = -EIO;
> > -             goto err;
> > +     if (op_type != OBJ_OP_READ) {
> > +             if (rbd_is_ro(rbd_dev)) {
> > +                     rbd_warn(rbd_dev, "%s on read-only mapping",
> > +                              obj_op_name(op_type));
> > +                     result = -EIO;
> > +                     goto err;
> > +             }
> > +             rbd_assert(!rbd_is_snap(rbd_dev));
>
> Just one question here, if block layer does not prevent write for
> readonly disk 100%,
> should we make it rbd-level readonly in rbd_ioctl_set_ro() when requested ?

No, the point is to divorce the read-only setting at the block layer
level from read-only setting in rbd.  Enforcing the block layer setting
is up to the block layer, rbd only enforces the rbd setting.  We allow
the block layer setting to be tweaked with BLKROSET, while rbd setting
is immutable (i.e. if you mapped with -o ro, you would have to unmap
and map without -o ro).  So we propagate rbd setting up to the block
layer, but the block layer setting isn't propagated down to rbd.

Thanks,

                Ilya



[Index of Archives]     [CEPH Users]     [Ceph Large]     [Ceph Dev]     [Information on CEPH]     [Linux BTRFS]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux