<feed xmlns='http://www.w3.org/2005/Atom'>
<title>linux.git/fs/sysfs, branch v2.6.31</title>
<subtitle>Linux kernel source tree</subtitle>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux.git/'/>
<entry>
<title>sysfs: fix hardlink count on device_move</title>
<updated>2009-07-28T20:45:21+00:00</updated>
<author>
<name>Peter Oberparleiter</name>
<email>oberpar@linux.vnet.ibm.com</email>
</author>
<published>2009-07-14T15:56:15+00:00</published>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux.git/commit/?id=0f58b44582001c8bcdb75f36cf85ebbe5170e959'/>
<id>0f58b44582001c8bcdb75f36cf85ebbe5170e959</id>
<content type='text'>
Update directory hardlink count when moving kobjects to a new parent.
Fixes the following problem which occurs when several devices are
moved to the same parent and then unregistered:

&gt; ls -laF /sys/devices/css0/defunct/
&gt; total 0
&gt; drwxr-xr-x 4294967295 root root    0 2009-07-14 17:02 ./
&gt; drwxr-xr-x        114 root root    0 2009-07-14 17:02 ../
&gt; drwxr-xr-x          2 root root    0 2009-07-14 17:01 power/
&gt; -rw-r--r--          1 root root 4096 2009-07-14 17:01 uevent

Signed-off-by: Peter Oberparleiter &lt;oberpar@linux.vnet.ibm.com&gt;
Cc: stable &lt;stable@kernel.org&gt;
Signed-off-by: Greg Kroah-Hartman &lt;gregkh@suse.de&gt;

</content>
<content type='xhtml'>
<div xmlns='http://www.w3.org/1999/xhtml'>
<pre>
Update directory hardlink count when moving kobjects to a new parent.
Fixes the following problem which occurs when several devices are
moved to the same parent and then unregistered:

&gt; ls -laF /sys/devices/css0/defunct/
&gt; total 0
&gt; drwxr-xr-x 4294967295 root root    0 2009-07-14 17:02 ./
&gt; drwxr-xr-x        114 root root    0 2009-07-14 17:02 ../
&gt; drwxr-xr-x          2 root root    0 2009-07-14 17:01 power/
&gt; -rw-r--r--          1 root root 4096 2009-07-14 17:01 uevent

Signed-off-by: Peter Oberparleiter &lt;oberpar@linux.vnet.ibm.com&gt;
Cc: stable &lt;stable@kernel.org&gt;
Signed-off-by: Greg Kroah-Hartman &lt;gregkh@suse.de&gt;

</pre>
</div>
</content>
</entry>
<entry>
<title>Free the memory allocated by memdup_user() in fs/sysfs/bin.c</title>
<updated>2009-07-08T16:34:07+00:00</updated>
<author>
<name>Catalin Marinas</name>
<email>catalin.marinas@arm.com</email>
</author>
<published>2009-07-08T10:17:34+00:00</published>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux.git/commit/?id=d5ce5b40bc66880d1732461d4b47d7fc3331ed30'/>
<id>d5ce5b40bc66880d1732461d4b47d7fc3331ed30</id>
<content type='text'>
Commit 1c8542c7bb replaced kmalloc() with memdup_user() in the write()
function but also dropped the kfree(temp). The memdup_user() function
allocates memory which is never freed.

Signed-off-by: Catalin Marinas &lt;catalin.marinas@arm.com&gt;
Cc: Parag Warudkar &lt;parag.warudkar@gmail.com&gt;
Signed-off-by: Linus Torvalds &lt;torvalds@linux-foundation.org&gt;
</content>
<content type='xhtml'>
<div xmlns='http://www.w3.org/1999/xhtml'>
<pre>
Commit 1c8542c7bb replaced kmalloc() with memdup_user() in the write()
function but also dropped the kfree(temp). The memdup_user() function
allocates memory which is never freed.

Signed-off-by: Catalin Marinas &lt;catalin.marinas@arm.com&gt;
Cc: Parag Warudkar &lt;parag.warudkar@gmail.com&gt;
Signed-off-by: Linus Torvalds &lt;torvalds@linux-foundation.org&gt;
</pre>
</div>
</content>
</entry>
<entry>
<title>Sysfs: fix possible memleak in sysfs_follow_link</title>
<updated>2009-06-16T04:30:23+00:00</updated>
<author>
<name>Armin Kuster</name>
<email>akuster@mvista.com</email>
</author>
<published>2009-04-29T17:29:59+00:00</published>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux.git/commit/?id=557411eb2ce61ef5e87bd759a6f86881586df857'/>
<id>557411eb2ce61ef5e87bd759a6f86881586df857</id>
<content type='text'>
There is the possiblity of a memory leak if a page is allocated and if
sysfs_getlink() fails in the sysfs_follow_link.

Signed-off-by: Armin Kuster &lt;akuster@mvista.com&gt;
Signed-off-by: Greg Kroah-Hartman &lt;gregkh@suse.de&gt;

</content>
<content type='xhtml'>
<div xmlns='http://www.w3.org/1999/xhtml'>
<pre>
There is the possiblity of a memory leak if a page is allocated and if
sysfs_getlink() fails in the sysfs_follow_link.

Signed-off-by: Armin Kuster &lt;akuster@mvista.com&gt;
Signed-off-by: Greg Kroah-Hartman &lt;gregkh@suse.de&gt;

</pre>
</div>
</content>
</entry>
<entry>
<title>sysfs: file.c: use create_singlethread_workqueue()</title>
<updated>2009-05-28T21:24:07+00:00</updated>
<author>
<name>Andrew Morton</name>
<email>akpm@linux-foundation.org</email>
</author>
<published>2009-05-07T19:36:53+00:00</published>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux.git/commit/?id=086a377edc969aea6c761176a7e4ff68f264d6fe'/>
<id>086a377edc969aea6c761176a7e4ff68f264d6fe</id>
<content type='text'>
We don't need a kernel thread per CPU for this application.

Acked-by: Alex Chiang &lt;achiang@hp.com&gt;
Cc: Lai Jiangshan &lt;laijs@cn.fujitsu.com&gt;
Cc: Peter Zijlstra &lt;a.p.zijlstra@chello.nl&gt;
Signed-off-by: Andrew Morton &lt;akpm@linux-foundation.org&gt;
Signed-off-by: Greg Kroah-Hartman &lt;gregkh@suse.de&gt;

</content>
<content type='xhtml'>
<div xmlns='http://www.w3.org/1999/xhtml'>
<pre>
We don't need a kernel thread per CPU for this application.

Acked-by: Alex Chiang &lt;achiang@hp.com&gt;
Cc: Lai Jiangshan &lt;laijs@cn.fujitsu.com&gt;
Cc: Peter Zijlstra &lt;a.p.zijlstra@chello.nl&gt;
Signed-off-by: Andrew Morton &lt;akpm@linux-foundation.org&gt;
Signed-off-by: Greg Kroah-Hartman &lt;gregkh@suse.de&gt;

</pre>
</div>
</content>
</entry>
<entry>
<title>sysfs: use memdup_user()</title>
<updated>2009-04-21T03:02:50+00:00</updated>
<author>
<name>Li Zefan</name>
<email>lizf@cn.fujitsu.com</email>
</author>
<published>2009-04-08T07:07:30+00:00</published>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux.git/commit/?id=1c8542c7bb239ef02fe21477acd9cdac04c1b640'/>
<id>1c8542c7bb239ef02fe21477acd9cdac04c1b640</id>
<content type='text'>
Remove open-coded memdup_user().

Signed-off-by: Li Zefan &lt;lizf@cn.fujitsu.com&gt;
Signed-off-by: Al Viro &lt;viro@zeniv.linux.org.uk&gt;
</content>
<content type='xhtml'>
<div xmlns='http://www.w3.org/1999/xhtml'>
<pre>
Remove open-coded memdup_user().

Signed-off-by: Li Zefan &lt;lizf@cn.fujitsu.com&gt;
Signed-off-by: Al Viro &lt;viro@zeniv.linux.org.uk&gt;
</pre>
</div>
</content>
</entry>
<entry>
<title>sysfs: sysfs poll keep the poll rule of regular file.</title>
<updated>2009-04-16T23:17:09+00:00</updated>
<author>
<name>KOSAKI Motohiro</name>
<email>kosaki.motohiro@jp.fujitsu.com</email>
</author>
<published>2009-04-09T04:53:22+00:00</published>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux.git/commit/?id=1af3557abdef34ee036a6de4cb79e24468544b8d'/>
<id>1af3557abdef34ee036a6de4cb79e24468544b8d</id>
<content type='text'>
Currently, following test programs don't finished.

% ruby -e '
Thread.new { sleep }
File.read("/sys/devices/system/cpu/cpu0/cpufreq/scaling_available_frequencies")
'

strace expose the reason.

...
open("/sys/devices/system/cpu/cpu0/cpufreq/scaling_available_frequencies", O_RDONLY|O_LARGEFILE) = 3
ioctl(3, SNDCTL_TMR_TIMEBASE or TCGETS, 0xbf9fa6b8) = -1 ENOTTY (Inappropriate ioctl for device)
fstat64(3, {st_mode=S_IFREG|0444, st_size=4096, ...}) = 0
_llseek(3, 0, [0], SEEK_CUR)            = 0
select(4, [3], NULL, NULL, NULL)        = 1 (in [3])
read(3, "1400000 1300000 1200000 1100000 1"..., 4096) = 62
select(4, [3], NULL, NULL, NULL


Because Ruby (the scripting language) VM assume select system-call
against regular file don't block.  it because SUSv3 says "Regular files
shall always poll TRUE for reading and writing".  see
http://www.opengroup.org/onlinepubs/009695399/functions/poll.html it
seems valid assumption.

But sysfs_poll() don't keep this rule although sysfs file can read and
write always.

This patch restore proper poll behavior to sysfs.
/sys/block/md*/md/sync_action polling application and another sysfs
updating sensitive application still can use POLLERR and POLLPRI.

Cc: Neil Brown &lt;neilb@suse.de&gt;
Signed-off-by: KOSAKI Motohiro &lt;kosaki.motohiro@jp.fujitsu.com&gt;
Signed-off-by: Greg Kroah-Hartman &lt;gregkh@suse.de&gt;

</content>
<content type='xhtml'>
<div xmlns='http://www.w3.org/1999/xhtml'>
<pre>
Currently, following test programs don't finished.

% ruby -e '
Thread.new { sleep }
File.read("/sys/devices/system/cpu/cpu0/cpufreq/scaling_available_frequencies")
'

strace expose the reason.

...
open("/sys/devices/system/cpu/cpu0/cpufreq/scaling_available_frequencies", O_RDONLY|O_LARGEFILE) = 3
ioctl(3, SNDCTL_TMR_TIMEBASE or TCGETS, 0xbf9fa6b8) = -1 ENOTTY (Inappropriate ioctl for device)
fstat64(3, {st_mode=S_IFREG|0444, st_size=4096, ...}) = 0
_llseek(3, 0, [0], SEEK_CUR)            = 0
select(4, [3], NULL, NULL, NULL)        = 1 (in [3])
read(3, "1400000 1300000 1200000 1100000 1"..., 4096) = 62
select(4, [3], NULL, NULL, NULL


Because Ruby (the scripting language) VM assume select system-call
against regular file don't block.  it because SUSv3 says "Regular files
shall always poll TRUE for reading and writing".  see
http://www.opengroup.org/onlinepubs/009695399/functions/poll.html it
seems valid assumption.

But sysfs_poll() don't keep this rule although sysfs file can read and
write always.

This patch restore proper poll behavior to sysfs.
/sys/block/md*/md/sync_action polling application and another sysfs
updating sensitive application still can use POLLERR and POLLPRI.

Cc: Neil Brown &lt;neilb@suse.de&gt;
Signed-off-by: KOSAKI Motohiro &lt;kosaki.motohiro@jp.fujitsu.com&gt;
Signed-off-by: Greg Kroah-Hartman &lt;gregkh@suse.de&gt;

</pre>
</div>
</content>
</entry>
<entry>
<title>sysfs: don't use global workqueue in sysfs_schedule_callback()</title>
<updated>2009-04-16T23:17:08+00:00</updated>
<author>
<name>Alex Chiang</name>
<email>achiang@hp.com</email>
</author>
<published>2009-03-25T21:11:36+00:00</published>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux.git/commit/?id=d110271e1f4140a9fb06d968b1afe9ca56a6064e'/>
<id>d110271e1f4140a9fb06d968b1afe9ca56a6064e</id>
<content type='text'>
A sysfs attribute using sysfs_schedule_callback() to commit suicide
may end up calling device_unregister(), which will eventually call
a driver's -&gt;remove function.

Drivers may call flush_scheduled_work() in their shutdown routines,
in which case lockdep will complain with something like the following:

  =============================================
  [ INFO: possible recursive locking detected ]
  2.6.29-rc8-kk #1
  ---------------------------------------------
  events/4/56 is trying to acquire lock:
  (events){--..}, at: [&lt;ffffffff80257fc0&gt;] flush_workqueue+0x0/0xa0

  but task is already holding lock:
  (events){--..}, at: [&lt;ffffffff80257648&gt;] run_workqueue+0x108/0x230

  other info that might help us debug this:
  3 locks held by events/4/56:
  #0:  (events){--..}, at: [&lt;ffffffff80257648&gt;] run_workqueue+0x108/0x230
  #1:  (&amp;ss-&gt;work){--..}, at: [&lt;ffffffff80257648&gt;] run_workqueue+0x108/0x230
  #2:  (pci_remove_rescan_mutex){--..}, at: [&lt;ffffffff803c10d1&gt;] remove_callback+0x21/0x40

  stack backtrace:
  Pid: 56, comm: events/4 Not tainted 2.6.29-rc8-kk #1
  Call Trace:
  [&lt;ffffffff8026dfcd&gt;] validate_chain+0xb7d/0x1260
  [&lt;ffffffff8026eade&gt;] __lock_acquire+0x42e/0xa40
  [&lt;ffffffff8026f148&gt;] lock_acquire+0x58/0x80
  [&lt;ffffffff80257fc0&gt;] ? flush_workqueue+0x0/0xa0
  [&lt;ffffffff8025800d&gt;] flush_workqueue+0x4d/0xa0
  [&lt;ffffffff80257fc0&gt;] ? flush_workqueue+0x0/0xa0
  [&lt;ffffffff80258070&gt;] flush_scheduled_work+0x10/0x20
  [&lt;ffffffffa0144065&gt;] e1000_remove+0x55/0xfe [e1000e]
  [&lt;ffffffff8033ee30&gt;] ? sysfs_schedule_callback_work+0x0/0x50
  [&lt;ffffffff803bfeb2&gt;] pci_device_remove+0x32/0x70
  [&lt;ffffffff80441da9&gt;] __device_release_driver+0x59/0x90
  [&lt;ffffffff80441edb&gt;] device_release_driver+0x2b/0x40
  [&lt;ffffffff804419d6&gt;] bus_remove_device+0xa6/0x120
  [&lt;ffffffff8043e46b&gt;] device_del+0x12b/0x190
  [&lt;ffffffff8043e4f6&gt;] device_unregister+0x26/0x70
  [&lt;ffffffff803ba969&gt;] pci_stop_dev+0x49/0x60
  [&lt;ffffffff803baab0&gt;] pci_remove_bus_device+0x40/0xc0
  [&lt;ffffffff803c10d9&gt;] remove_callback+0x29/0x40
  [&lt;ffffffff8033ee4f&gt;] sysfs_schedule_callback_work+0x1f/0x50
  [&lt;ffffffff8025769a&gt;] run_workqueue+0x15a/0x230
  [&lt;ffffffff80257648&gt;] ? run_workqueue+0x108/0x230
  [&lt;ffffffff8025846f&gt;] worker_thread+0x9f/0x100
  [&lt;ffffffff8025bce0&gt;] ? autoremove_wake_function+0x0/0x40
  [&lt;ffffffff802583d0&gt;] ? worker_thread+0x0/0x100
  [&lt;ffffffff8025b89d&gt;] kthread+0x4d/0x80
  [&lt;ffffffff8020d4ba&gt;] child_rip+0xa/0x20
  [&lt;ffffffff8020cebc&gt;] ? restore_args+0x0/0x30
  [&lt;ffffffff8025b850&gt;] ? kthread+0x0/0x80
  [&lt;ffffffff8020d4b0&gt;] ? child_rip+0x0/0x20

Although we know that the device_unregister path will never acquire
a lock that a driver might try to acquire in its -&gt;remove, in general
we should never attempt to flush a workqueue from within the same
workqueue, and lockdep rightly complains.

So as long as sysfs attributes cannot commit suicide directly and we
are stuck with this callback mechanism, put the sysfs callbacks on
their own workqueue instead of the global one.

This has the side benefit that if a suicidal sysfs attribute kicks
off a long chain of -&gt;remove callbacks, we no longer induce a long
delay on the global queue.

This also fixes a missing module_put in the error path introduced
by sysfs-only-allow-one-scheduled-removal-callback-per-kobj.patch.

We never destroy the workqueue, but I'm not sure that's a
problem.

Reported-by: Kenji Kaneshige &lt;kaneshige.kenji@jp.fujitsu.com&gt;
Tested-by: Kenji Kaneshige &lt;kaneshige.kenji@jp.fujitsu.com&gt;
Signed-off-by: Alex Chiang &lt;achiang@hp.com&gt;
Signed-off-by: Greg Kroah-Hartman &lt;gregkh@suse.de&gt;

</content>
<content type='xhtml'>
<div xmlns='http://www.w3.org/1999/xhtml'>
<pre>
A sysfs attribute using sysfs_schedule_callback() to commit suicide
may end up calling device_unregister(), which will eventually call
a driver's -&gt;remove function.

Drivers may call flush_scheduled_work() in their shutdown routines,
in which case lockdep will complain with something like the following:

  =============================================
  [ INFO: possible recursive locking detected ]
  2.6.29-rc8-kk #1
  ---------------------------------------------
  events/4/56 is trying to acquire lock:
  (events){--..}, at: [&lt;ffffffff80257fc0&gt;] flush_workqueue+0x0/0xa0

  but task is already holding lock:
  (events){--..}, at: [&lt;ffffffff80257648&gt;] run_workqueue+0x108/0x230

  other info that might help us debug this:
  3 locks held by events/4/56:
  #0:  (events){--..}, at: [&lt;ffffffff80257648&gt;] run_workqueue+0x108/0x230
  #1:  (&amp;ss-&gt;work){--..}, at: [&lt;ffffffff80257648&gt;] run_workqueue+0x108/0x230
  #2:  (pci_remove_rescan_mutex){--..}, at: [&lt;ffffffff803c10d1&gt;] remove_callback+0x21/0x40

  stack backtrace:
  Pid: 56, comm: events/4 Not tainted 2.6.29-rc8-kk #1
  Call Trace:
  [&lt;ffffffff8026dfcd&gt;] validate_chain+0xb7d/0x1260
  [&lt;ffffffff8026eade&gt;] __lock_acquire+0x42e/0xa40
  [&lt;ffffffff8026f148&gt;] lock_acquire+0x58/0x80
  [&lt;ffffffff80257fc0&gt;] ? flush_workqueue+0x0/0xa0
  [&lt;ffffffff8025800d&gt;] flush_workqueue+0x4d/0xa0
  [&lt;ffffffff80257fc0&gt;] ? flush_workqueue+0x0/0xa0
  [&lt;ffffffff80258070&gt;] flush_scheduled_work+0x10/0x20
  [&lt;ffffffffa0144065&gt;] e1000_remove+0x55/0xfe [e1000e]
  [&lt;ffffffff8033ee30&gt;] ? sysfs_schedule_callback_work+0x0/0x50
  [&lt;ffffffff803bfeb2&gt;] pci_device_remove+0x32/0x70
  [&lt;ffffffff80441da9&gt;] __device_release_driver+0x59/0x90
  [&lt;ffffffff80441edb&gt;] device_release_driver+0x2b/0x40
  [&lt;ffffffff804419d6&gt;] bus_remove_device+0xa6/0x120
  [&lt;ffffffff8043e46b&gt;] device_del+0x12b/0x190
  [&lt;ffffffff8043e4f6&gt;] device_unregister+0x26/0x70
  [&lt;ffffffff803ba969&gt;] pci_stop_dev+0x49/0x60
  [&lt;ffffffff803baab0&gt;] pci_remove_bus_device+0x40/0xc0
  [&lt;ffffffff803c10d9&gt;] remove_callback+0x29/0x40
  [&lt;ffffffff8033ee4f&gt;] sysfs_schedule_callback_work+0x1f/0x50
  [&lt;ffffffff8025769a&gt;] run_workqueue+0x15a/0x230
  [&lt;ffffffff80257648&gt;] ? run_workqueue+0x108/0x230
  [&lt;ffffffff8025846f&gt;] worker_thread+0x9f/0x100
  [&lt;ffffffff8025bce0&gt;] ? autoremove_wake_function+0x0/0x40
  [&lt;ffffffff802583d0&gt;] ? worker_thread+0x0/0x100
  [&lt;ffffffff8025b89d&gt;] kthread+0x4d/0x80
  [&lt;ffffffff8020d4ba&gt;] child_rip+0xa/0x20
  [&lt;ffffffff8020cebc&gt;] ? restore_args+0x0/0x30
  [&lt;ffffffff8025b850&gt;] ? kthread+0x0/0x80
  [&lt;ffffffff8020d4b0&gt;] ? child_rip+0x0/0x20

Although we know that the device_unregister path will never acquire
a lock that a driver might try to acquire in its -&gt;remove, in general
we should never attempt to flush a workqueue from within the same
workqueue, and lockdep rightly complains.

So as long as sysfs attributes cannot commit suicide directly and we
are stuck with this callback mechanism, put the sysfs callbacks on
their own workqueue instead of the global one.

This has the side benefit that if a suicidal sysfs attribute kicks
off a long chain of -&gt;remove callbacks, we no longer induce a long
delay on the global queue.

This also fixes a missing module_put in the error path introduced
by sysfs-only-allow-one-scheduled-removal-callback-per-kobj.patch.

We never destroy the workqueue, but I'm not sure that's a
problem.

Reported-by: Kenji Kaneshige &lt;kaneshige.kenji@jp.fujitsu.com&gt;
Tested-by: Kenji Kaneshige &lt;kaneshige.kenji@jp.fujitsu.com&gt;
Signed-off-by: Alex Chiang &lt;achiang@hp.com&gt;
Signed-off-by: Greg Kroah-Hartman &lt;gregkh@suse.de&gt;

</pre>
</div>
</content>
</entry>
<entry>
<title>mm: page_mkwrite change prototype to match fault: fix sysfs</title>
<updated>2009-04-01T15:59:14+00:00</updated>
<author>
<name>Hugh Dickins</name>
<email>hugh@veritas.com</email>
</author>
<published>2009-03-31T22:23:24+00:00</published>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux.git/commit/?id=851a039cc547b33b8139fe6d7c2bbfb158e2724e'/>
<id>851a039cc547b33b8139fe6d7c2bbfb158e2724e</id>
<content type='text'>
Fix warnings and return values in sysfs bin_page_mkwrite(), fixing
fs/sysfs/bin.c: In function `bin_page_mkwrite':
fs/sysfs/bin.c:250: warning: passing argument 2 of `bb-&gt;vm_ops-&gt;page_mkwrite' from incompatible pointer type
fs/sysfs/bin.c: At top level:
fs/sysfs/bin.c:280: warning: initialization from incompatible pointer type

Expects to have my [PATCH next] sysfs: fix some bin_vm_ops errors

Signed-off-by: Hugh Dickins &lt;hugh@veritas.com&gt;
Cc: Nick Piggin &lt;npiggin@suse.de&gt;
Cc: "Eric W. Biederman" &lt;ebiederm@aristanetworks.com&gt;
Signed-off-by: Andrew Morton &lt;akpm@linux-foundation.org&gt;
Signed-off-by: Linus Torvalds &lt;torvalds@linux-foundation.org&gt;
</content>
<content type='xhtml'>
<div xmlns='http://www.w3.org/1999/xhtml'>
<pre>
Fix warnings and return values in sysfs bin_page_mkwrite(), fixing
fs/sysfs/bin.c: In function `bin_page_mkwrite':
fs/sysfs/bin.c:250: warning: passing argument 2 of `bb-&gt;vm_ops-&gt;page_mkwrite' from incompatible pointer type
fs/sysfs/bin.c: At top level:
fs/sysfs/bin.c:280: warning: initialization from incompatible pointer type

Expects to have my [PATCH next] sysfs: fix some bin_vm_ops errors

Signed-off-by: Hugh Dickins &lt;hugh@veritas.com&gt;
Cc: Nick Piggin &lt;npiggin@suse.de&gt;
Cc: "Eric W. Biederman" &lt;ebiederm@aristanetworks.com&gt;
Signed-off-by: Andrew Morton &lt;akpm@linux-foundation.org&gt;
Signed-off-by: Linus Torvalds &lt;torvalds@linux-foundation.org&gt;
</pre>
</div>
</content>
</entry>
<entry>
<title>Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs-2.6</title>
<updated>2009-03-27T23:23:12+00:00</updated>
<author>
<name>Linus Torvalds</name>
<email>torvalds@linux-foundation.org</email>
</author>
<published>2009-03-27T23:23:12+00:00</published>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux.git/commit/?id=3ae5080f4c2e293229508dabe7c8a90af4e4c460'/>
<id>3ae5080f4c2e293229508dabe7c8a90af4e4c460</id>
<content type='text'>
* 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs-2.6: (37 commits)
  fs: avoid I_NEW inodes
  Merge code for single and multiple-instance mounts
  Remove get_init_pts_sb()
  Move common mknod_ptmx() calls into caller
  Parse mount options just once and copy them to super block
  Unroll essentials of do_remount_sb() into devpts
  vfs: simple_set_mnt() should return void
  fs: move bdev code out of buffer.c
  constify dentry_operations: rest
  constify dentry_operations: configfs
  constify dentry_operations: sysfs
  constify dentry_operations: JFS
  constify dentry_operations: OCFS2
  constify dentry_operations: GFS2
  constify dentry_operations: FAT
  constify dentry_operations: FUSE
  constify dentry_operations: procfs
  constify dentry_operations: ecryptfs
  constify dentry_operations: CIFS
  constify dentry_operations: AFS
  ...
</content>
<content type='xhtml'>
<div xmlns='http://www.w3.org/1999/xhtml'>
<pre>
* 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs-2.6: (37 commits)
  fs: avoid I_NEW inodes
  Merge code for single and multiple-instance mounts
  Remove get_init_pts_sb()
  Move common mknod_ptmx() calls into caller
  Parse mount options just once and copy them to super block
  Unroll essentials of do_remount_sb() into devpts
  vfs: simple_set_mnt() should return void
  fs: move bdev code out of buffer.c
  constify dentry_operations: rest
  constify dentry_operations: configfs
  constify dentry_operations: sysfs
  constify dentry_operations: JFS
  constify dentry_operations: OCFS2
  constify dentry_operations: GFS2
  constify dentry_operations: FAT
  constify dentry_operations: FUSE
  constify dentry_operations: procfs
  constify dentry_operations: ecryptfs
  constify dentry_operations: CIFS
  constify dentry_operations: AFS
  ...
</pre>
</div>
</content>
</entry>
<entry>
<title>constify dentry_operations: sysfs</title>
<updated>2009-03-27T18:44:02+00:00</updated>
<author>
<name>Al Viro</name>
<email>viro@zeniv.linux.org.uk</email>
</author>
<published>2009-02-20T06:01:46+00:00</published>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux.git/commit/?id=ee1ec32903fc3139af00ebc7ee483dabca3f4fa5'/>
<id>ee1ec32903fc3139af00ebc7ee483dabca3f4fa5</id>
<content type='text'>
Signed-off-by: Al Viro &lt;viro@zeniv.linux.org.uk&gt;
</content>
<content type='xhtml'>
<div xmlns='http://www.w3.org/1999/xhtml'>
<pre>
Signed-off-by: Al Viro &lt;viro@zeniv.linux.org.uk&gt;
</pre>
</div>
</content>
</entry>
</feed>
