From: Darrick J. Wong Date: Sun, 1 Mar 2020 17:34:11 +0000 (-0500) Subject: libxfs: remove dangerous casting between cache_node and xfs_buf X-Git-Tag: v5.5.0-rc1~7 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=063516bba3f5f37c22f52664826839fca97fc010;p=thirdparty%2Fxfsprogs-dev.git libxfs: remove dangerous casting between cache_node and xfs_buf Get rid of all the dangerous casting between cache_node and xfs_buf since we can use container_of now. Signed-off-by: Darrick J. Wong Reviewed-by: Christoph Hellwig Signed-off-by: Eric Sandeen --- diff --git a/libxfs/rdwr.c b/libxfs/rdwr.c index f92c7db93..68e8e014b 100644 --- a/libxfs/rdwr.c +++ b/libxfs/rdwr.c @@ -301,8 +301,9 @@ libxfs_bhash(cache_key_t key, unsigned int hashsize, unsigned int hashshift) static int libxfs_bcompare(struct cache_node *node, cache_key_t key) { - struct xfs_buf *bp = (struct xfs_buf *)node; - struct xfs_bufkey *bkey = (struct xfs_bufkey *)key; + struct xfs_buf *bp = container_of(node, struct xfs_buf, + b_node); + struct xfs_bufkey *bkey = (struct xfs_bufkey *)key; if (bp->b_target->dev == bkey->buftarg->dev && bp->b_bn == bkey->blkno) { @@ -1052,7 +1053,8 @@ static void libxfs_brelse( struct cache_node *node) { - struct xfs_buf *bp = (struct xfs_buf *)node; + struct xfs_buf *bp = container_of(node, struct xfs_buf, + b_node); if (!bp) return; @@ -1117,7 +1119,8 @@ static int libxfs_bflush( struct cache_node *node) { - struct xfs_buf *bp = (struct xfs_buf *)node; + struct xfs_buf *bp = container_of(node, struct xfs_buf, + b_node); if (!bp->b_error && bp->b_flags & LIBXFS_B_DIRTY) return libxfs_bwrite(bp);