diff options
author | Bobby Powers <bobbypowers@gmail.com> | 2012-02-22 00:29:47 -0500 |
---|---|---|
committer | H. Peter Anvin <hpa@zytor.com> | 2012-02-23 21:28:52 -0500 |
commit | f044db4cb4bf16893812d35b5fbeaaf3e30c9215 (patch) | |
tree | 65d30aa0a19f6ff7db2be6fd1f1ac159ad1dc6f2 | |
parent | cf420048b3b2af9ce928d35cc5455c646c9dd2f7 (diff) |
fs: Fix close_on_exec pointer in alloc_fdtable
alloc_fdtable allocates space for the open_fds and close_on_exec
bitfields together, as 2 * nr / BITS_PER_BYTE. close_on_exec needs to
point to open_fds + nr / BITS_PER_BYTE, not open_fds + nr /
BITS_PER_LONG, as introducted in 1fd36adc: Replace the fd_sets in
struct fdtable with an array of unsigned longs.
Signed-off-by: Bobby Powers <bobbypowers@gmail.com>
Link: http://lkml.kernel.org/r/1329888587-3087-1-git-send-email-bobbypowers@gmail.com
Acked-by: David Howells <dhowells@redhat.com>
Signed-off-by: H. Peter Anvin <hpa@zytor.com>
-rw-r--r-- | fs/file.c | 2 |
1 files changed, 1 insertions, 1 deletions
@@ -179,7 +179,7 @@ static struct fdtable * alloc_fdtable(unsigned int nr) | |||
179 | if (!data) | 179 | if (!data) |
180 | goto out_arr; | 180 | goto out_arr; |
181 | fdt->open_fds = data; | 181 | fdt->open_fds = data; |
182 | data += nr / BITS_PER_LONG; | 182 | data += nr / BITS_PER_BYTE; |
183 | fdt->close_on_exec = data; | 183 | fdt->close_on_exec = data; |
184 | fdt->next = NULL; | 184 | fdt->next = NULL; |
185 | 185 | ||