From: Andreas Gruenbacher Date: Mon, 6 Mar 2017 17:58:42 +0000 (-0500) Subject: gfs2: Avoid alignment hole in struct lm_lockname X-Git-Tag: v4.10.6~4 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=a69813714424f0cbbf1d7440b84c5fe4ae3d69af;p=thirdparty%2Fkernel%2Fstable.git gfs2: Avoid alignment hole in struct lm_lockname commit 28ea06c46fbcab63fd9a55531387b7928a18a590 upstream. Commit 88ffbf3e03 switches to using rhashtables for glocks, hashing over the entire struct lm_lockname instead of its individual fields. On some architectures, struct lm_lockname contains a hole of uninitialized memory due to alignment rules, which now leads to incorrect hash values. Get rid of that hole. Signed-off-by: Andreas Gruenbacher Signed-off-by: Bob Peterson Signed-off-by: Greg Kroah-Hartman --- diff --git a/fs/gfs2/incore.h b/fs/gfs2/incore.h index a6a3389a07fc6..51519c2836b5b 100644 --- a/fs/gfs2/incore.h +++ b/fs/gfs2/incore.h @@ -207,7 +207,7 @@ struct lm_lockname { struct gfs2_sbd *ln_sbd; u64 ln_number; unsigned int ln_type; -}; +} __packed __aligned(sizeof(int)); #define lm_name_equal(name1, name2) \ (((name1)->ln_number == (name2)->ln_number) && \