diff --git a/crypto/rmd160.c b/crypto/rmd160.c
index e9fd5f6a0acb22bb95cc6cbb89fa972f39316efb..f001ec775e1fcd6d22a39fc453b953cccc851ec6 100644
--- a/crypto/rmd160.c
+++ b/crypto/rmd160.c
@@ -26,7 +26,7 @@
 struct rmd160_ctx {
 	u64 byte_count;
 	u32 state[5];
-	u32 buffer[16];
+	__le32 buffer[16];
 };
 
 #define K1  RMD_K1
@@ -52,7 +52,7 @@ struct rmd160_ctx {
 	(c) = rol32((c), 10); \
 }
 
-static void rmd160_transform(u32 *state, u32 const *in)
+static void rmd160_transform(u32 *state, const __le32 *in)
 {
 	u32 aa, bb, cc, dd, ee, aaa, bbb, ccc, ddd, eee;
 
@@ -313,8 +313,8 @@ static void rmd160_final(struct crypto_tfm *tfm, u8 *out)
 {
 	struct rmd160_ctx *rctx = crypto_tfm_ctx(tfm);
 	u32 i, index, padlen;
-	u64 bits;
-	u32 *dst = (u32 *)out;
+	__le64 bits;
+	__le32 *dst = (__le32 *)out;
 	static const u8 padding[64] = { 0x80, };
 
 	bits = cpu_to_le64(rctx->byte_count << 3);
diff --git a/crypto/rmd256.c b/crypto/rmd256.c
index b08852690706f9de97a4916b4edb60f5eed194a2..e3de5b4cb47f99bb46fea596426f869b770b68b0 100644
--- a/crypto/rmd256.c
+++ b/crypto/rmd256.c
@@ -26,7 +26,7 @@
 struct rmd256_ctx {
 	u64 byte_count;
 	u32 state[8];
-	u32 buffer[16];
+	__le32 buffer[16];
 };
 
 #define K1  RMD_K1
@@ -48,7 +48,7 @@ struct rmd256_ctx {
 	(a) = rol32((a), (s)); \
 }
 
-static void rmd256_transform(u32 *state, u32 const *in)
+static void rmd256_transform(u32 *state, const __le32 *in)
 {
 	u32 aa, bb, cc, dd, aaa, bbb, ccc, ddd, tmp;
 
@@ -288,8 +288,8 @@ static void rmd256_final(struct crypto_tfm *tfm, u8 *out)
 {
 	struct rmd256_ctx *rctx = crypto_tfm_ctx(tfm);
 	u32 i, index, padlen;
-	u64 bits;
-	u32 *dst = (u32 *)out;
+	__le64 bits;
+	__le32 *dst = (__le32 *)out;
 	static const u8 padding[64] = { 0x80, };
 
 	bits = cpu_to_le64(rctx->byte_count << 3);
diff --git a/crypto/rmd320.c b/crypto/rmd320.c
index dba03ecf53603f2fc7ad726426eaf5f46efef84e..b143d66e42c8095c3742589f06106dfe8b65b793 100644
--- a/crypto/rmd320.c
+++ b/crypto/rmd320.c
@@ -26,7 +26,7 @@
 struct rmd320_ctx {
 	u64 byte_count;
 	u32 state[10];
-	u32 buffer[16];
+	__le32 buffer[16];
 };
 
 #define K1  RMD_K1
@@ -52,7 +52,7 @@ struct rmd320_ctx {
 	(c) = rol32((c), 10); \
 }
 
-static void rmd320_transform(u32 *state, u32 const *in)
+static void rmd320_transform(u32 *state, const __le32 *in)
 {
 	u32 aa, bb, cc, dd, ee, aaa, bbb, ccc, ddd, eee, tmp;
 
@@ -337,8 +337,8 @@ static void rmd320_final(struct crypto_tfm *tfm, u8 *out)
 {
 	struct rmd320_ctx *rctx = crypto_tfm_ctx(tfm);
 	u32 i, index, padlen;
-	u64 bits;
-	u32 *dst = (u32 *)out;
+	__le64 bits;
+	__le32 *dst = (__le32 *)out;
 	static const u8 padding[64] = { 0x80, };
 
 	bits = cpu_to_le64(rctx->byte_count << 3);