diff options
Diffstat (limited to 'fs/lockd/host.c')
-rw-r--r-- | fs/lockd/host.c | 32 |
1 files changed, 11 insertions, 21 deletions
diff --git a/fs/lockd/host.c b/fs/lockd/host.c index 1f9d72a7a030..b9eeafe99a66 100644 --- a/fs/lockd/host.c +++ b/fs/lockd/host.c | |||
@@ -31,13 +31,11 @@ static unsigned long next_gc; | |||
31 | static int nrhosts; | 31 | static int nrhosts; |
32 | static DEFINE_MUTEX(nlm_host_mutex); | 32 | static DEFINE_MUTEX(nlm_host_mutex); |
33 | 33 | ||
34 | |||
35 | static void nlm_gc_hosts(void); | 34 | static void nlm_gc_hosts(void); |
36 | static struct nsm_handle * __nsm_find(const struct sockaddr_in *, | 35 | static struct nsm_handle *nsm_find(const struct sockaddr_in *sin, |
37 | const char *, unsigned int, int); | 36 | const char *hostname, |
38 | static struct nsm_handle * nsm_find(const struct sockaddr_in *sin, | 37 | const size_t hostname_len, |
39 | const char *hostname, | 38 | const int create); |
40 | unsigned int hostname_len); | ||
41 | 39 | ||
42 | /* | 40 | /* |
43 | * Hash function must work well on big- and little-endian platforms | 41 | * Hash function must work well on big- and little-endian platforms |
@@ -187,7 +185,7 @@ static struct nlm_host *nlm_lookup_host(int server, | |||
187 | atomic_inc(&nsm->sm_count); | 185 | atomic_inc(&nsm->sm_count); |
188 | else { | 186 | else { |
189 | host = NULL; | 187 | host = NULL; |
190 | nsm = nsm_find(sin, hostname, hostname_len); | 188 | nsm = nsm_find(sin, hostname, hostname_len, 1); |
191 | if (!nsm) { | 189 | if (!nsm) { |
192 | dprintk("lockd: nlm_lookup_host failed; " | 190 | dprintk("lockd: nlm_lookup_host failed; " |
193 | "no nsm handle\n"); | 191 | "no nsm handle\n"); |
@@ -419,8 +417,7 @@ void nlm_host_rebooted(const struct sockaddr_in *sin, | |||
419 | struct nsm_handle *nsm; | 417 | struct nsm_handle *nsm; |
420 | struct nlm_host *host; | 418 | struct nlm_host *host; |
421 | 419 | ||
422 | /* Find the NSM handle for this peer */ | 420 | nsm = nsm_find(sin, hostname, hostname_len, 0); |
423 | nsm = __nsm_find(sin, hostname, hostname_len, 0); | ||
424 | if (nsm == NULL) { | 421 | if (nsm == NULL) { |
425 | dprintk("lockd: never saw rebooted peer '%.*s' before\n", | 422 | dprintk("lockd: never saw rebooted peer '%.*s' before\n", |
426 | hostname_len, hostname); | 423 | hostname_len, hostname); |
@@ -560,10 +557,10 @@ nlm_gc_hosts(void) | |||
560 | static LIST_HEAD(nsm_handles); | 557 | static LIST_HEAD(nsm_handles); |
561 | static DEFINE_SPINLOCK(nsm_lock); | 558 | static DEFINE_SPINLOCK(nsm_lock); |
562 | 559 | ||
563 | static struct nsm_handle * | 560 | static struct nsm_handle *nsm_find(const struct sockaddr_in *sin, |
564 | __nsm_find(const struct sockaddr_in *sin, | 561 | const char *hostname, |
565 | const char *hostname, unsigned int hostname_len, | 562 | const size_t hostname_len, |
566 | int create) | 563 | const int create) |
567 | { | 564 | { |
568 | struct nsm_handle *nsm = NULL; | 565 | struct nsm_handle *nsm = NULL; |
569 | struct nsm_handle *pos; | 566 | struct nsm_handle *pos; |
@@ -575,7 +572,7 @@ __nsm_find(const struct sockaddr_in *sin, | |||
575 | if (printk_ratelimit()) { | 572 | if (printk_ratelimit()) { |
576 | printk(KERN_WARNING "Invalid hostname \"%.*s\" " | 573 | printk(KERN_WARNING "Invalid hostname \"%.*s\" " |
577 | "in NFS lock request\n", | 574 | "in NFS lock request\n", |
578 | hostname_len, hostname); | 575 | (int)hostname_len, hostname); |
579 | } | 576 | } |
580 | return NULL; | 577 | return NULL; |
581 | } | 578 | } |
@@ -623,13 +620,6 @@ found: | |||
623 | return nsm; | 620 | return nsm; |
624 | } | 621 | } |
625 | 622 | ||
626 | static struct nsm_handle * | ||
627 | nsm_find(const struct sockaddr_in *sin, const char *hostname, | ||
628 | unsigned int hostname_len) | ||
629 | { | ||
630 | return __nsm_find(sin, hostname, hostname_len, 1); | ||
631 | } | ||
632 | |||
633 | /* | 623 | /* |
634 | * Release an NSM handle | 624 | * Release an NSM handle |
635 | */ | 625 | */ |