/* * linux/drivers/video/bt455.h * * Copyright 2003 Thiemo Seufer * Copyright 2016 Maciej W. Rozycki * * This file is subject to the terms and conditions of the GNU General * Public License. See the file COPYING in the main directory of this * archive for more details. */ #include /* * Bt455 byte-wide registers, 32-bit aligned. */ struct bt455_regs { volatile u8 addr_cmap; u8 pad0[3]; volatile u8 addr_cmap_data; u8 pad1[3]; volatile u8 addr_clr; u8 pad2[3]; volatile u8 addr_ovly; u8 pad3[3]; }; static inline void bt455_select_reg(struct bt455_regs *regs, int ir) { mb(); regs->addr_cmap = ir & 0x0f; } static inline void bt455_reset_reg(struct bt455_regs *regs) { mb(); regs->addr_clr = 0; } /* * Read/write to a Bt455 color map register. */ static inline void bt455_read_cmap_next(struct bt455_regs *regs, u8 *grey) { mb(); regs->addr_cmap_data; rmb(); *grey = regs->addr_cmap_data & 0xf; rmb(); regs->addr_cmap_data; } static inline void bt455_write_cmap_next(struct bt455_regs *regs, u8 grey) { wmb(); regs->addr_cmap_data = 0x0; wmb(); regs->addr_cmap_data = grey & 0xf; wmb(); regs->addr_cmap_data = 0x0; } static inline void bt455_write_ovly_next(struct bt455_regs *regs, u8 grey) { wmb(); regs->addr_ovly = 0x0; wmb(); regs->addr_ovly = grey & 0xf; wmb(); regs->addr_ovly = 0x0; } static inline void bt455_read_cmap_entry(struct bt455_regs *regs, int cr, u8 *grey) { bt455_select_reg(regs, cr); bt455_read_cmap_next(regs, grey); } static inline void bt455_write_cmap_entry(struct bt455_regs *regs, int cr, u8 grey) { bt455_select_reg(regs, cr); bt455_write_cmap_next(regs, grey); } static inline void bt455_write_ovly_entry(struct bt455_regs *regs, u8 grey) { bt455_reset_reg(regs); bt455_write_ovly_next(regs, grey); } dt-bindings/reset/mt2701-resets.h?id=059aa734824165507c65fd30a55ff000afd14983'>treecommitdiff
diff options
context:
space:
mode:
authorChuck Lever <chuck.lever@oracle.com>2017-01-22 14:04:29 -0500
committerTrond Myklebust <trond.myklebust@primarydata.com>2017-01-24 12:50:47 -0500
commit059aa734824165507c65fd30a55ff000afd14983 (patch)
tree63defb4adb0656c4af72a05081b181b163f94b3e /include/dt-bindings/reset/mt2701-resets.h
parent8ac092519ad91931c96d306c4bfae2c6587c325f (diff)
nfs: Don't increment lock sequence ID after NFS4ERR_MOVED
Xuan Qi reports that the Linux NFSv4 client failed to lock a file that was migrated. The steps he observed on the wire: 1. The client sent a LOCK request to the source server 2. The source server replied NFS4ERR_MOVED 3. The client switched to the destination server 4. The client sent the same LOCK request to the destination server with a bumped lock sequence ID 5. The destination server rejected the LOCK request with NFS4ERR_BAD_SEQID RFC 3530 section 8.1.5 provides a list of NFS errors which do not bump a lock sequence ID. However, RFC 3530 is now obsoleted by RFC 7530. In RFC 7530 section 9.1.7, this list has been updated by the addition of NFS4ERR_MOVED. Reported-by: Xuan Qi <xuan.qi@oracle.com> Signed-off-by: Chuck Lever <chuck.lever@oracle.com> Cc: stable@vger.kernel.org # v3.7+ Signed-off-by: Trond Myklebust <trond.myklebust@primarydata.com>
Diffstat (limited to 'include/dt-bindings/reset/mt2701-resets.h')