~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/fs/zonefs/sysfs.c

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /fs/zonefs/sysfs.c (Version linux-6.12-rc7) and /fs/zonefs/sysfs.c (Version linux-5.12.19)


  1 // SPDX-License-Identifier: GPL-2.0                 1 
  2 /*                                                
  3  * Simple file system for zoned block devices     
  4  *                                                
  5  * Copyright (C) 2022 Western Digital Corporat    
  6  */                                               
  7 #include <linux/fs.h>                             
  8 #include <linux/seq_file.h>                       
  9 #include <linux/blkdev.h>                         
 10                                                   
 11 #include "zonefs.h"                               
 12                                                   
 13 struct zonefs_sysfs_attr {                        
 14         struct attribute attr;                    
 15         ssize_t (*show)(struct zonefs_sb_info     
 16 };                                                
 17                                                   
 18 #define ZONEFS_SYSFS_ATTR_RO(name) \              
 19 static struct zonefs_sysfs_attr zonefs_sysfs_a    
 20                                                   
 21 #define ATTR_LIST(name) &zonefs_sysfs_attr_##n    
 22                                                   
 23 static ssize_t zonefs_sysfs_attr_show(struct k    
 24                                       struct a    
 25 {                                                 
 26         struct zonefs_sb_info *sbi =              
 27                 container_of(kobj, struct zone    
 28         struct zonefs_sysfs_attr *zonefs_attr     
 29                 container_of(attr, struct zone    
 30                                                   
 31         if (!zonefs_attr->show)                   
 32                 return 0;                         
 33                                                   
 34         return zonefs_attr->show(sbi, buf);       
 35 }                                                 
 36                                                   
 37 static ssize_t max_wro_seq_files_show(struct z    
 38 {                                                 
 39         return sysfs_emit(buf, "%u\n", sbi->s_    
 40 }                                                 
 41 ZONEFS_SYSFS_ATTR_RO(max_wro_seq_files);          
 42                                                   
 43 static ssize_t nr_wro_seq_files_show(struct zo    
 44 {                                                 
 45         return sysfs_emit(buf, "%d\n", atomic_    
 46 }                                                 
 47 ZONEFS_SYSFS_ATTR_RO(nr_wro_seq_files);           
 48                                                   
 49 static ssize_t max_active_seq_files_show(struc    
 50 {                                                 
 51         return sysfs_emit(buf, "%u\n", sbi->s_    
 52 }                                                 
 53 ZONEFS_SYSFS_ATTR_RO(max_active_seq_files);       
 54                                                   
 55 static ssize_t nr_active_seq_files_show(struct    
 56 {                                                 
 57         return sysfs_emit(buf, "%d\n", atomic_    
 58 }                                                 
 59 ZONEFS_SYSFS_ATTR_RO(nr_active_seq_files);        
 60                                                   
 61 static struct attribute *zonefs_sysfs_attrs[]     
 62         ATTR_LIST(max_wro_seq_files),             
 63         ATTR_LIST(nr_wro_seq_files),              
 64         ATTR_LIST(max_active_seq_files),          
 65         ATTR_LIST(nr_active_seq_files),           
 66         NULL,                                     
 67 };                                                
 68 ATTRIBUTE_GROUPS(zonefs_sysfs);                   
 69                                                   
 70 static void zonefs_sysfs_sb_release(struct kob    
 71 {                                                 
 72         struct zonefs_sb_info *sbi =              
 73                 container_of(kobj, struct zone    
 74                                                   
 75         complete(&sbi->s_kobj_unregister);        
 76 }                                                 
 77                                                   
 78 static const struct sysfs_ops zonefs_sysfs_att    
 79         .show   = zonefs_sysfs_attr_show,         
 80 };                                                
 81                                                   
 82 static const struct kobj_type zonefs_sb_ktype     
 83         .default_groups = zonefs_sysfs_groups,    
 84         .sysfs_ops      = &zonefs_sysfs_attr_o    
 85         .release        = zonefs_sysfs_sb_rele    
 86 };                                                
 87                                                   
 88 static struct kobject *zonefs_sysfs_root;         
 89                                                   
 90 int zonefs_sysfs_register(struct super_block *    
 91 {                                                 
 92         struct zonefs_sb_info *sbi = ZONEFS_SB    
 93         int ret;                                  
 94                                                   
 95         super_set_sysfs_name_id(sb);              
 96         init_completion(&sbi->s_kobj_unregiste    
 97         ret = kobject_init_and_add(&sbi->s_kob    
 98                                    zonefs_sysf    
 99         if (ret) {                                
100                 kobject_put(&sbi->s_kobj);        
101                 wait_for_completion(&sbi->s_ko    
102                 return ret;                       
103         }                                         
104                                                   
105         sbi->s_sysfs_registered = true;           
106                                                   
107         return 0;                                 
108 }                                                 
109                                                   
110 void zonefs_sysfs_unregister(struct super_bloc    
111 {                                                 
112         struct zonefs_sb_info *sbi = ZONEFS_SB    
113                                                   
114         if (!sbi || !sbi->s_sysfs_registered)     
115                 return;                           
116                                                   
117         kobject_del(&sbi->s_kobj);                
118         kobject_put(&sbi->s_kobj);                
119         wait_for_completion(&sbi->s_kobj_unreg    
120 }                                                 
121                                                   
122 int __init zonefs_sysfs_init(void)                
123 {                                                 
124         zonefs_sysfs_root = kobject_create_and    
125         if (!zonefs_sysfs_root)                   
126                 return -ENOMEM;                   
127                                                   
128         return 0;                                 
129 }                                                 
130                                                   
131 void zonefs_sysfs_exit(void)                      
132 {                                                 
133         kobject_put(zonefs_sysfs_root);           
134         zonefs_sysfs_root = NULL;                 
135 }                                                 
136                                                   

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php