aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVlad Yasevich <vladislav.yasevich@hp.com>2006-01-17 14:54:06 -0500
committerSridhar Samudrala <sri@us.ibm.com>2006-01-17 14:54:06 -0500
commit38b0e42aba928d9929a26ec23b850c36a31fca5f (patch)
tree934a3678968b7f5f19bf6543f527c0cef39b25c8
parent49392e5ecf608da6770fd8723b534a0fc851edc4 (diff)
[SCTP]: Fix sctp_assoc_seq_show() panics on big-endian systems.
This patch corrects the panic by casting the argument to the pointer of correct size. On big-endian systems we ended up loading only 32 bits of data because we are treating the pointer as an int*. By treating this pointer as loff_t*, we'll load the full 64 bits and then let regular integer demotion take place which will give us the correct value. Signed-off-by: Vlad Yaseivch <vladislav.yasevich@hp.com> Signed-off-by: Sridhar Samudrala <sri@us.ibm.com>
-rw-r--r--net/sctp/proc.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/net/sctp/proc.c b/net/sctp/proc.c
index 1b5e5b119f79..d47a52c303a8 100644
--- a/net/sctp/proc.c
+++ b/net/sctp/proc.c
@@ -210,7 +210,7 @@ static int sctp_eps_seq_show(struct seq_file *seq, void *v)
210 struct sctp_ep_common *epb; 210 struct sctp_ep_common *epb;
211 struct sctp_endpoint *ep; 211 struct sctp_endpoint *ep;
212 struct sock *sk; 212 struct sock *sk;
213 int hash = *(int *)v; 213 int hash = *(loff_t *)v;
214 214
215 if (hash >= sctp_ep_hashsize) 215 if (hash >= sctp_ep_hashsize)
216 return -ENOMEM; 216 return -ENOMEM;
@@ -313,7 +313,7 @@ static int sctp_assocs_seq_show(struct seq_file *seq, void *v)
313 struct sctp_ep_common *epb; 313 struct sctp_ep_common *epb;
314 struct sctp_association *assoc; 314 struct sctp_association *assoc;
315 struct sock *sk; 315 struct sock *sk;
316 int hash = *(int *)v; 316 int hash = *(loff_t *)v;
317 317
318 if (hash >= sctp_assoc_hashsize) 318 if (hash >= sctp_assoc_hashsize)
319 return -ENOMEM; 319 return -ENOMEM;