• T
    pNFS: Fix CB_LAYOUTRECALL stateid verification · 793b7fe5
    Trond Myklebust 提交于
    We want to evaluate in this order:
    
    If the client holds no layout for this inode, then return
    NFS4ERR_NOMATCHING_LAYOUT; it probably forgot the layout.
    
    If the client finds the inode among the list of layouts, but the corresponding
    stateid has not yet been initialised, then return NFS4ERR_DELAY to ask the
    server to retry once the outstanding LAYOUTGET is complete.
    
    If the current layout stateid's "other" field does not match the recalled
    stateid, return NFS4ERR_BAD_STATEID.
    
    If already processing a layout recall with a newer stateid, return
    NFS4ERR_OLD_STATEID. This can only happens for servers that are
    non-compliant with the NFSv4.1 protocol.
    
    If already processing a layout recall with an older stateid, return
    NFS4ERR_DELAY to ask the server to retry once the outstanding
    LAYOUTRETURN is complete. Again, this is technically incompliant with
    the NFSv4.1 protocol.
    
    If the current layout sequence id is newer than the recalled stateid's
    sequence id, return NFS4ERR_OLD_STATEID. This too implies protocol
    non-compliance.
    
    If the current layout sequence id is older than the recalled stateid's
    sequence id+1, return NFS4ERR_DELAY.
    Signed-off-by: NTrond Myklebust <trond.myklebust@primarydata.com>
    793b7fe5
callback_proc.c 16.7 KB