Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1424292AbWLHEMU (ORCPT ); Thu, 7 Dec 2006 23:12:20 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1424304AbWLHEMU (ORCPT ); Thu, 7 Dec 2006 23:12:20 -0500 Received: from liaag2ad.mx.compuserve.com ([149.174.40.155]:32832 "EHLO liaag2ad.mx.compuserve.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1424292AbWLHEMT (ORCPT ); Thu, 7 Dec 2006 23:12:19 -0500 Date: Thu, 7 Dec 2006 23:02:04 -0500 From: Chuck Ebbert <76306.1226@compuserve.com> Subject: [patch] Document how to decode an IOCTL number To: linux-kernel Cc: Andrew Morton Message-ID: <200612072306_MC3-1-D448-DB6A@compuserve.com> MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1234 Lines: 42 Document how to decode a binary IOCTL number. Signed-off-by: Chuck Ebbert <76306.1226@compuserve.com> --- Documentation/ioctl/ioctl-decoding.txt | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) --- /dev/null +++ 2.6.19.0.5-32smp/Documentation/ioctl/ioctl-decoding.txt @@ -0,0 +1,24 @@ +To decode a hex IOCTL code: + +Most architecures use this generic format, but check +include/ARCH/ioctl.h for specifics, e.g. powerpc +uses 3 bits to encode read/write and 13 bits for size. + + bits meaning + 31-30 00 - no parameters: uses _IO macro + 10 - read: _IOR + 01 - write: _IOW + 11 - read/write: _IOWR + + 29-16 size of arguments + + 15-8 ascii character supposedly + unique to each driver + + 7-0 function # + + + So for example 0x82187201 is a read with arg length of 0x218, +character 'r' function 1. Grepping the source reveals this is: + +#define VFAT_IOCTL_READDIR_BOTH _IOR('r', 1, struct dirent [2]) -- Chuck "Even supernovas have their duller moments." - 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/