Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1759768Ab1CDPrV (ORCPT ); Fri, 4 Mar 2011 10:47:21 -0500 Received: from mail-px0-f174.google.com ([209.85.212.174]:53251 "EHLO mail-px0-f174.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752121Ab1CDPrU (ORCPT ); Fri, 4 Mar 2011 10:47:20 -0500 DomainKey-Signature: a=rsa-sha1; c=nofws; d=gmail.com; s=gamma; h=date:from:to:subject:message-id:mime-version:content-type :content-disposition:user-agent; b=v5UNu/Grz2DeESL3yeRVDu+hdElmRSgjEOp3U71zmRcFCISXyITahOzkH1yhEy8zB1 m50ROaHFdjS7EPM2hEW0P9BrdcIY+umn7AQ5M2vWtX7fNtflnsf6xtEn48l752aAkPKL etFLOhYEtQOIusxekqgKumbvuKY/gEMqhvGmM= Date: Fri, 4 Mar 2011 23:47:06 +0800 From: Dave Young To: Andrew Morton , Ingo Molnar , David Miller , Don Zickus , linux-kernel@vger.kernel.org Subject: [PATCH 03/04 v2] sysctl: add proc_dointvec_unsigned handler Message-ID: <20110304154706.GC14672@darkstar> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline User-Agent: Mutt/1.5.20 (2009-06-14) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2348 Lines: 59 Add proc_dointvec_unsigned sysctl handler for positive value cases Signed-off-by: Dave Young --- include/linux/sysctl.h | 2 ++ kernel/sysctl.c | 26 ++++++++++++++++++++++++++ 2 files changed, 28 insertions(+) --- linux-2.6.orig/kernel/sysctl.c 2011-03-03 11:17:21.796661240 +0800 +++ linux-2.6/kernel/sysctl.c 2011-03-03 11:17:39.126661201 +0800 @@ -2459,6 +2459,32 @@ int proc_dointvec_bool(struct ctl_table } EXPORT_SYMBOL(proc_dointvec_bool); +/** + * proc_dointvec_unsigned - read a vector of integers with positive values + * @table: the sysctl table + * @write: %TRUE if this is a write to the sysctl file + * @buffer: the user buffer + * @lenp: the size of the user buffer + * @ppos: file position + * + * Reads/writes up to table->maxlen/sizeof(unsigned int) integer + * values from/to the user buffer, treated as an ASCII string. + * + * This routine will ensure the values are positive. + * + * Returns 0 on success. + */ +int proc_dointvec_unsigned(struct ctl_table *table, int write, + void __user *buffer, size_t *lenp, loff_t *ppos) +{ + struct do_proc_dointvec_minmax_conv_param param = { + .min = &zero, + }; + return do_proc_dointvec(table, write, buffer, lenp, ppos, + do_proc_dointvec_minmax_conv, ¶m); +} +EXPORT_SYMBOL(proc_dointvec_unsigned); + static int __do_proc_doulongvec_minmax(void *data, struct ctl_table *table, int write, void __user *buffer, size_t *lenp, loff_t *ppos, --- linux-2.6.orig/include/linux/sysctl.h 2011-03-03 11:16:16.000000000 +0800 +++ linux-2.6/include/linux/sysctl.h 2011-03-03 11:18:15.529994450 +0800 @@ -972,6 +972,8 @@ extern int proc_dointvec_minmax(struct c void __user *, size_t *, loff_t *); extern int proc_dointvec_bool(struct ctl_table *, int, void __user *, size_t *, loff_t *); +extern int proc_dointvec_unsigned(struct ctl_table *, int, + void __user *, size_t *, loff_t *); extern int proc_dointvec_jiffies(struct ctl_table *, int, void __user *, size_t *, loff_t *); extern int proc_dointvec_userhz_jiffies(struct ctl_table *, int, -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/