• Daniel Henrique Barboza's avatar
    RISC-V: KVM: do not EOPNOTSUPP in set_one_reg() zicbo(m|z) · e29f5791
    Daniel Henrique Barboza authored
    
    
    zicbom_block_size and zicboz_block_size have a peculiar API: they can be
    read via get_one_reg() but any write will return a EOPNOTSUPP.
    
    It makes sense to return a 'not supported' error since both values can't
    be changed, but as far as userspace goes they're regs that are throwing
    the same EOPNOTSUPP error even if they were read beforehand via
    get_one_reg(), even if the same  read value is being written back.
    EOPNOTSUPP is also returned even if ZICBOM/ZICBOZ aren't enabled in the
    host.
    
    Change both to work more like their counterparts in get_one_reg() and
    return -ENOENT if their respective extensions aren't available. After
    that, check if the userspace is written a valid value (i.e. the host
    value). Throw an -EINVAL if that's not case, let it slide otherwise.
    
    This allows both regs to be read/written by userspace in a 'lazy'
    manner, as long as the userspace doesn't change the reg vals.
    Suggested-by: default avatarAndrew Jones <ajones@ventanamicro.com>
    Signed-off-by: default avatarDaniel Henrique Barboza <dbarboza@ventanamicro.com>
    Reviewed-by: default avatarAndrew Jones <ajones@ventanamicro.com>
    Signed-off-by: default avatarAnup Patel <anup@brainfault.org>
    e29f5791
vcpu_onereg.c 17.5 KB