Christoph Hellwig <hch@xxxxxx> writes: > Switch over all instances used directly as methods using these sed > expressions: > > sed -i -e 's/\.read\(\s*=\s*\)seq_read/\.read_iter\1seq_read_iter/g' This sucks, really. I just got a patch against this converting the changed version to DEFINE_SHOW_ATTRIBUTE(somefile) and thereby removing the whole open coded gunk. If we do a tree wide change like this, then can we pretty please use a coccinelle script to convert all trivial instances to use DEFINE_SHOW_ATTRIBUTE so we don't have to touch the same place over and over. Out of 375 places changed in your patch something about 2/3rd fall into the trivial category: static int debug_stats_open(struct inode *inode, struct file *filp) { return single_open(filp, debug_stats_show, NULL); } static const struct file_operations debug_stats_fops = { .open = debug_stats_open, .read = seq_read, .llseek = seq_lseek, .release = single_release, }; which can be replaced by: DEFINE_SHOW_ATTRIBUTE(debug_stats); removing 12 lines of gunk and one central place to do the iter change. I'm pretty sure that quite some of the others which have only an additional write function can be replaced by a new macro DEFINE_RW_ATTRIBUTE() or such. Needs some thought and maybe some cocci help from Julia, but that's way better than this brute force sed thing which results in malformed crap like this: static const struct file_operations debug_stats_fops = { .open = debug_stats_open, .read_iter = seq_read_iter, .llseek = seq_lseek, .release = single_release, }; and proliferates the copy and paste voodoo programming. Thanks, tglx