On Wed, Jun 18, 2008 at 08:30:51PM +0200, Louis Rilling wrote:While this patch is correct on the face, I'd like to try a different approach. I wasn't thinking about it right. See, config_*_init_type_name() are generally a create-time thing. Almost everyone uses it without error checking because they know it is safe; they are usually using a static name. config_item_set_name() can only error if strlen(name)>CONFIGFS_ITEM_NAME_LEN. That's why config_*_init_type_name() are void. In other words, we shouldn't be adding useless error-check boilerplate for already-safe things. But there are a couple of users of config_*_set_type_name() that aren't safe. The lockspace in fs/dlm/config.c is one (lockspace names can be 64 characters). The config_*_init_type_name() helpers are quite convenient. I see two choices: 1) Make your changes to return errors from config_*_init_type_name(), but don't check the errors on known-safe usage (small static strings). 2) Provide two API, one that is void and one that is not, so that known-safe usage can use the void call (and BUG_ON() if the strlen() is off), while other usage checks the errors. Joel -- Life's Little Instruction Book #3 "Watch a sunrise at least once a year." Joel Becker Principal Software Developer Oracle E-mail: joel.becker@oracle.com Phone: (650) 506-8127 --
| Srivatsa Vaddagiri | containers (was Re: -mm merge plans for 2.6.23) |
| Greg KH | [GIT PATCH] driver core patches against 2.6.24 |
| Tarkan Erimer | Re: Dual-Licensing Linux Kernel with GPL V2 and GPL V3 |
| Benjamin Herrenschmidt | Re: [PATCH] Remove process freezer from suspend to RAM pathway |
git: | |
| Jarek Poplawski | [PATCH take 2] pkt_sched: Protect gen estimators under est_lock. |
| David Miller | [GIT]: Networking |
| Gerhard Pircher | 3c59x: shared interrupt problem |
| Gerrit Renker | [PATCH 27/37] dccp: Integration of dynamic feature activation - part 2 (server side) |
