提交 003cb608 编写于 作者: T Tejun Heo

percpu: add __percpu sparse annotations to fs

Add __percpu sparse annotations to fs.

These annotations are to make sparse consider percpu variables to be
in a different address space and warn if accessed without going
through percpu accessors.  This patch doesn't affect normal builds.
Signed-off-by: NTejun Heo <tj@kernel.org>
Cc: "Theodore Ts'o" <tytso@mit.edu>
Cc: Trond Myklebust <Trond.Myklebust@netapp.com>
Cc: Alex Elder <aelder@sgi.com>
Cc: Christoph Hellwig <hch@infradead.org>
Cc: Alexander Viro <viro@zeniv.linux.org.uk>
上级 43cf38eb
...@@ -1014,7 +1014,7 @@ struct ext4_sb_info { ...@@ -1014,7 +1014,7 @@ struct ext4_sb_info {
atomic_t s_lock_busy; atomic_t s_lock_busy;
/* locality groups */ /* locality groups */
struct ext4_locality_group *s_locality_groups; struct ext4_locality_group __percpu *s_locality_groups;
/* for write statistics */ /* for write statistics */
unsigned long s_sectors_written_start; unsigned long s_sectors_written_start;
......
...@@ -57,12 +57,12 @@ static inline void nfs_add_fscache_stats(struct inode *inode, ...@@ -57,12 +57,12 @@ static inline void nfs_add_fscache_stats(struct inode *inode,
} }
#endif #endif
static inline struct nfs_iostats *nfs_alloc_iostats(void) static inline struct nfs_iostats __percpu *nfs_alloc_iostats(void)
{ {
return alloc_percpu(struct nfs_iostats); return alloc_percpu(struct nfs_iostats);
} }
static inline void nfs_free_iostats(struct nfs_iostats *stats) static inline void nfs_free_iostats(struct nfs_iostats __percpu *stats)
{ {
if (stats != NULL) if (stats != NULL)
free_percpu(stats); free_percpu(stats);
......
...@@ -243,7 +243,7 @@ typedef struct xfs_mount { ...@@ -243,7 +243,7 @@ typedef struct xfs_mount {
struct xfs_qmops *m_qm_ops; /* vector of XQM ops */ struct xfs_qmops *m_qm_ops; /* vector of XQM ops */
atomic_t m_active_trans; /* number trans frozen */ atomic_t m_active_trans; /* number trans frozen */
#ifdef HAVE_PERCPU_SB #ifdef HAVE_PERCPU_SB
xfs_icsb_cnts_t *m_sb_cnts; /* per-cpu superblock counters */ xfs_icsb_cnts_t __percpu *m_sb_cnts; /* per-cpu superblock counters */
unsigned long m_icsb_counters; /* disabled per-cpu counters */ unsigned long m_icsb_counters; /* disabled per-cpu counters */
struct notifier_block m_icsb_notifier; /* hotplug cpu notifier */ struct notifier_block m_icsb_notifier; /* hotplug cpu notifier */
struct mutex m_icsb_mutex; /* balancer sync lock */ struct mutex m_icsb_mutex; /* balancer sync lock */
......
...@@ -66,7 +66,7 @@ struct vfsmount { ...@@ -66,7 +66,7 @@ struct vfsmount {
int mnt_pinned; int mnt_pinned;
int mnt_ghosts; int mnt_ghosts;
#ifdef CONFIG_SMP #ifdef CONFIG_SMP
int *mnt_writers; int __percpu *mnt_writers;
#else #else
int mnt_writers; int mnt_writers;
#endif #endif
......
...@@ -105,7 +105,7 @@ struct nfs_server { ...@@ -105,7 +105,7 @@ struct nfs_server {
struct rpc_clnt * client; /* RPC client handle */ struct rpc_clnt * client; /* RPC client handle */
struct rpc_clnt * client_acl; /* ACL RPC client handle */ struct rpc_clnt * client_acl; /* ACL RPC client handle */
struct nlm_host *nlm_host; /* NLM client handle */ struct nlm_host *nlm_host; /* NLM client handle */
struct nfs_iostats * io_stats; /* I/O statistics */ struct nfs_iostats __percpu *io_stats; /* I/O statistics */
struct backing_dev_info backing_dev_info; struct backing_dev_info backing_dev_info;
atomic_long_t writeback; /* number of writeback pages */ atomic_long_t writeback; /* number of writeback pages */
int flags; /* various flags */ int flags; /* various flags */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册