Release notes for v2.5.7-pre1 Summary of changes from v2.5.6 to v2.5.7-pre1 ============================================ <torvalds@penguin.transmeta.com> (02/03/08 1.385) Fix parport_cs compile troubles <torvalds@penguin.transmeta.com> (02/03/08 1.386) Split out "msync" logic into a file of its own. No actual code changes. <torvalds@penguin.transmeta.com> (02/03/08 1.387) msync cleanups <torvalds@penguin.transmeta.com> (02/03/08 1.388) mm cleanup: split out mincore() system call from filemap.c <torvalds@home.transmeta.com> (02/03/08 1.389) Fix missing '!' in set_fs_altroot() <davidm@wailua.hpl.hp.com> (02/03/09 1.369.15.1) ia64-patches <davidm@wailua.hpl.hp.com> (02/03/09 1.369.15.2) This patch got dropped from the VM_DATA_DEFAULT_FLAGS patch sent earlier. <davidm@wailua.hpl.hp.com> (02/03/09 1.369.15.3) Update EFI RTC driver to version 0.3. <davidm@wailua.hpl.hp.com> (02/03/09 1.369.15.4) Fix two typos in comments. <ch@hpl.hp.com> (02/03/09 1.375.2.18) [PATCH] 1033/1: latest 2.5.x badge4 def-config <davidm@wailua.hpl.hp.com> (02/03/09 1.369.15.5) p4 <davidm@wailua.hpl.hp.com> (02/03/09 1.369.15.6) pci.c: Print values of type dma_addr_t by casting to unsigned long and using the %lx format. <davidm@wailua.hpl.hp.com> (02/03/09 1.369.15.7) as-flags.diff <stefan.eletzhofer@eletztrick.de> (02/03/09 1.375.2.19) [PATCH] 1008/1: PCMCIA MECR handling This patch changes PCMCIA MECR handling such that: - MECR is changed in one function only and atomically - a additional callback for boards to allow them to tweak BS values on a per-socket basis Note: I don't know wether or not tish changes are WIP or done already. If so, please drop it and send me a note. Changes files: linux/drivers/pcmcia/sa1100_generic.h linux/drivers/pcmcia/sa1100_generic.c <xkaspa06@stud.fee.vutbr.cz> (02/03/09 1.375.2.20) [PATCH] 1039/1: EXPORT_SYMBOL(dma_spin_lock) for ALSA Even I do not realy use any ISA code of ALSA on my iPAQ I need it for compilation. As I build ALSA as modules, the dma_spin_lock symbol is missing. I have seen both definitions of dma_spin_lock (in kernel/dma.c and arch/arm/kernel/dma.c) same as EXPORT_SYMBOL in kernel/ksyms.c, but I think, exporting it in arch/arm/kernel/dma.c should be better then making confusion in kernel/ksyms.c 2Russel: If you don't think this is good solution, we should discuss this in linux-arm-kernel mailing list <src@flint.arm.linux.org.uk> (02/03/09 1.384.1.1) Update Makefile, sa1110 cpufreq code. Drop static flash mapping from system3.c <davidm@wailua.hpl.hp.com> (02/03/09 1.375.25.2) Fixup bad merge. <xkaspa06@stud.fee.vutbr.cz> (02/03/09 1.384.1.3) [PATCH] 1036/1: allow APM to be build as module (for 2.5.5) (modified) This is updated version of patch 1002/1 . As build system in 2.5.5 kernel allows same name of .c files in different directories when computing dependencies and versioning information, the patch becomes simple. Now it just modify appropriate Makefile (in arch/arm/mach-sa1100) and exports one symbol in arch/arm/mach-sa10/pm.c) This patch replace 1002/1. (Hope, this is what you want Russel :) <davidm@wailua.hpl.hp.com> (02/03/09 1.375.25.3) Fix formatting in Makefile. <rmk@flint.arm.linux.org.uk> (02/03/10 1.375.12.3) Re-jig ARMv3 and up page table handing for better correctness with Ingo's highmem code. This also helps with Riel's rmap VM, and eliminates the slab overhead for these processors. For more information, see: http://lists.arm.linux.org.uk/pipermail/linux-arm-kernel/2002-March/008089.html <jamey@crl.dec.com> (02/03/10 1.384.1.4) [PATCH] 889/1: updated jornada720 config file Updates the jornada720 config file to build with 2.4.17-rmk4 <rmk@flint.arm.linux.org.uk> (02/03/10 1.384.2.1) Make iq80310_gettimeoffset() return the currect time delta. Remove redundant irq_enter/irq_exit calls. <rmk@flint.arm.linux.org.uk> (02/03/10 1.384.2.2) Fix up couple of bugs in Integrator PCI code. <nico@cam.org> (02/03/10 1.384.1.5) [PATCH] 995/1: better EBSA110 idle This should bring better performances as all interrupts are always run with clock switching enabled and the idle spinning always with the lower clock. This also keeps the brokenness of that architecture localized while preserving the sanity of the common SA idle function. <rmk@flint.arm.linux.org.uk> (02/03/10 1.384.2.3) Tidy up abort handler selection. Use new glue.h to select relevant handler to allow for better optimisation. <rmk@flint.arm.linux.org.uk> (02/03/10 1.384.2.4) Split out copy_user_page/clear_user_page to allow more efficient selection depending on processor features. <rusty@rustcorp.com.au> (02/03/10 1.390) [PATCH] Futexes IV (Fast Lightweight Userspace Semaphores) Fast user-space mutex implementation, allowing user space to do all of the normal handling, with a minimal fallback to kernel space for when there is lock contention. The kernel space implementation does not keep any per-lock data structures, but instead does a fast hash on the physical page and offset of the user-space lock when contended. Thus no build/teardown costs, or any scalability costs wrt metadata. Updated syscall numbers for 2.5.6, and changed FUTEX_UP/DOWN definitions to be more logical for future expansions (eg. r/w). <davem@nuts.ninka.net> (02/03/11 1.384.3.1) Move IP-specific identity information out of struct sock. Fix -EFAULT handling in TCP direct user copy handling. Use struct initializers in IPV6 ndisc code. <davem@nuts.ninka.net> (02/03/11 1.384.3.2) Remove bogus tw->tb NULL check in tcp_timewait_kill. This is what made the following bug harder to find: Put new timewait buckets into the bind hash _FIRST_ before they appear into the established hash to kill some races with socket creation/lookup. <davem@nuts.ninka.net> (02/03/11 1.384.3.3) Avoid using read/modify/write cycles to set frag_off field of IPv4 header in hot paths. Use __constant_htons as appropriate. <davem@nuts.ninka.net> (02/03/11 1.384.3.4) Do not report inode numbers as negative in networking procfs nodes <davem@nuts.ninka.net> (02/03/11 1.384.3.5) Export ip_net_protocol_{register,unregister} and ip_nat_used_tuple. Minor cleanups to conntrack/irc modules/configuration. From Harald Welte and the netfilter team. <davem@nuts.ninka.net> (02/03/11 1.384.3.6) Never set IP_DF for ICMP packets. <davem@nuts.ninka.net> (02/03/11 1.384.3.7) RED packet scheduler bug fixes from Jamal Hadi Salim. <davem@nuts.ninka.net> (02/03/11 1.384.3.8) Make sock_writeable (used mostly by datagram protocols) more reasonable. Kill all references to SOCK_MIN_WRITE_SPACE and kill its definition. Replace with appropriate sock_writeable calls. <davem@nuts.ninka.net> (02/03/11 1.384.3.9) sock_register inet6_family_ops before we do init calls which might try to create ipv6 sockets. <davem@nuts.ninka.net> (02/03/11 1.384.3.10) Major revamp of VLAN layer: 1) Add hw acceleration hooks for device drivers. 2) Move private declarations out of public includes. 3) Mark file local functions and data as static. 4) Use a small hash table for VLAN group lookups. 5) Correct all the locking and device ref counting. 6) No longer mark it as CONFIG_EXPERIMENTAL. <davem@nuts.ninka.net> (02/03/11 1.384.4.1) Fix scheduler deadlock on some platforms. Some platforms need to grab mm->page_table_lock during switch_mm(). On the other hand code like swap_out() in mm/vmscan.c needs to hold mm->page_table_lock during wakeups which needs to grab the runqueue lock. This creates a conflict and the resolution chosen here is to not hold the runqueue lock during context_switch(). The implementation is specifically a "frozen" state implemented as a spinlock, which is held around the context_switch() call. This allows the runqueue lock to be dropped during this time yet prevent another cpu from running the "not switched away from yet" task. <davem@nuts.ninka.net> (02/03/11 1.384.4.2) Fix CAN_MIGRATE_TASK macro to use p arg it gets instead of tmp explicitly. <davem@nuts.ninka.net> (02/03/11 1.384.4.3) Use cpu_logical_map as appropriate. <davem@nuts.ninka.net> (02/03/11 1.384.4.4) If cache_decay_ticks is large enough, the migration thread startup at boot time can fail. Fix this by temporarily setting cache_decay_ticks to zero around migration thread startup. <davem@nuts.ninka.net> (02/03/11 1.384.5.1) Add back check_pgt_cache call. Add nop definition for x86. <davem@nuts.ninka.net> (02/03/11 1.384.5.2) Fix typos. <rmk@flint.arm.linux.org.uk> (02/03/11 1.384.1.8) Fix up spinlocking/IRQ handling in SCSI drivers for Acorn machines. <rmk@flint.arm.linux.org.uk> (02/03/11 1.384.1.9) Bug fixes for Acorn network drivers. <rmk@flint.arm.linux.org.uk> (02/03/11 1.384.1.10) Update Acorn serial drivers. <davem@nuts.ninka.net> (02/03/11 1.384.6.1) Sparc64 updates mostly build fixes: 1) Update for schedule_tail and switch_to arg changes. 2) Update for PTE highmem. 3) Add random ioctls to ioctl32 translations. 4) Kill migration IPI. 5) Fixup scheduler bitmap function and move into bitops.h <davem@nuts.ninka.net> (02/03/11 1.384.6.2) Do not expand stack for non-faulting loads <davem@nuts.ninka.net> (02/03/11 1.384.6.3) Fix PCI IRQ probing for some bridging situations. Use PCI_SLOT instead of hard-coded shift. <davem@nuts.ninka.net> (02/03/11 1.384.6.4) Use pci_memspace_mask instead of hard-coded value 0xffffffff. <davem@nuts.ninka.net> (02/03/11 1.384.6.5) Work around some hw bugs in Schizo PCI controllers. <davem@nuts.ninka.net> (02/03/11 1.384.6.6) Use dma_addr_t for hblock_dvma. Make device probe failure more robust. <davem@nuts.ninka.net> (02/03/11 1.384.6.7) Init FHC controller registers earlier so that Zilog interrupt mappings are not clobbered on Sun Enterprise servers. Fix some FHC register offsets. Sometimes IPIs can allow BHs to run with interrupts disabled, fix that by rescheduling them to normal PIL based interrupts. <davem@nuts.ninka.net> (02/03/11 1.384.6.8) Read lock around files->fd[] accesses. <davem@nuts.ninka.net> (02/03/11 1.384.6.9) Add SI_DETHREAD <davem@nuts.ninka.net> (02/03/11 1.384.6.10) Add per_cpu linker script bits for Sparc. <bcrl@toomuch.toronto.redhat.com> (02/03/11 1.384.7.1) Avoid looping in write_inode_now since the sync_one changes now ensure __sync_one is called once the inode is unlocked. <dalecki@evision-ventures.com> (02/03/11 1.388.1.1) [PATCH] 2.5.6 IDE 18 No fixes for new problems which occured since today, just syncup. - Remove help text about suitable compiler versions, which is obsoleted by the overall kernel reality. - Remove traces of not progressing work in progress code for the CONFIG_BLK_DEV_ADMA option as well as the empty ide-adma.c file as well as CONFIG_BLK_DEV_IDEDMA_TCQ. - Remove redundant CONFIG_BLK_DEV_IDE != n check in ide/Config.in. Hugh, this is a tricky one... - Add EXPORT_SYMBOL(ide_fops) again, since it's used in ide-cd.c add a note there that this is actually possibly adding the same device twice to the devfs stuff. - Finally change the MAINTAINER entry. Just too many persons bogged me about it and it doesn't take me too much time apparently. - Apply sis.patch.20020304_1. - Don't call ide_release_dma twice in cleanup_ata, since ide_unregister is already calling it for us. Change prototype of ide_unregister to take a hwif as parameter and disable an ioctl for removing/scanning hwif from the list of handled interfaces. I see no reasons for having it and doing it is the fastest DOS attack on my home system I know about it. Contrary to the comments found here and there, hdparm doesn't use it. There are better hot plugging interfaces coming to the kernel right now anyway. - Wrap invalidate_drives in ide_unregister under the ide_lock instead of disabling and enabling interrupts during this operation. There are plenty of other places where the IDE drivers are enabling and disabling interrupts just to protect some data structures. - Don't call destroy_proc_ide_drives(hwif) for every single drive out there.This routine takes a hwif as a parameter. - Resync with the instable 2.5.6... <dalecki@evision-ventures.com> (02/03/11 1.388.1.2) [PATCH] 2.5.6 IDE 19 - Fix oversight in replacement of sti() cli() pairs for data structure access protection. This finally resolvs my problems with the 2.5.6 kernel series. Now I'm in fact quite puzzled how it was even possible for the system to get into the init stage without this fix.. - Fix usage of CONFIG_BLK_DEV_IDE_MODULES instead of CONFIG_BLK_DEV_IDE_MODULE. - Make idescsi_init global for usage in systems without module support enabled. - Apply Pavels Macheks patch for suspend support. Whatever some persons argue that it's not fully implemented, I think that we are in development series right now. I don't buy the mock-up examples for problems with either outdated or broken hardware. Micro Drives are for example expected to be drop in replacements for CF cards in digital cameras and I would rather expect them to be very tolerant about the driver in front of them. And then the WB caches of IDE devices are not caches in the sense of a MESI cache, they are more like buffer caches and should therefore flush them self after s short period of inactivity without the application of any special flush command. The upcoming explicit flushing commands in the ATA standard are about data integrity guarantees in high reliability systems, like DB servers for example, and not about simple cache validity. - Apply Vojtech Pavliks fix to the VIA host chip initialization code. - Add missing if-defs around PIO timing tables. - Fix max() min() related compile warnings in IDE-scsi. <jt@bougret.hpl.hp.com> (02/03/11 1.388.1.3) [PATCH] New wireless driver API part 2 Quick summary : this patch build on the first part to offer two important new features : o Wireless Events o Wireless Cell Scanning Wireless Events are events generated by device, driver or the wireless subsystem. It allows for example a device to notify user space when it register to a new cell (roaming) or loose contact with the current Access Points. Currently, the other defined events include some configuration changes and packet drop due to excessive retries, more may come in the future. All those events are useful for MobileIP, V-Handoff and Ad-Hoc routing. Wireless Cell Scanning is a generic API to allow device/drive to report Wireless Cells discovered (including ESSID, frequency and QoS). This is similar to what is available in WindowsXP (except that it's compliant to Wireless Extensions). This patch has been submitted for review on this list a couple of time in January, has been on my web page since and used intensively by other people. It was rediffed to 2.5.6. Driver patches have been submitted to maintainers. <vojtech@suse.cz> (02/03/11 1.388.1.5) [PATCH] My AMD IDE driver, v2.7 This patch replaces the current AMD IDE driver (by Andre Hedrick) by mine. Myself I think my implementation is much cleaner, but I'll leave upon others to judge that. My driver also additionally supports the AMD-8111 IDE. It's well tested, and I'd like to have this in the kernel instead of what's there now. <rem@osdl.org> (02/03/11 1.388.1.6) [PATCH] 2.5.6-pre3 Fix small race in BSD accounting Below is a patch to remove a small race in kernel/acct.c. <rem@osdl.org> (02/03/11 1.388.1.7) [PATCH] 2.5.6-pre3 Fix small race in BSD accounting While looking at the bug fix for part 1 I coded up this patch to change the BSD accounting code to use a spinlock instead of the BKL. <alan@lxorguk.ukuu.org.uk> (02/03/11 1.388.1.8) [PATCH] 2.5.6-pre3 Fix BSD accounting rlimit Fix rlimit on accounting file. <akpm@zip.com.au> (02/03/11 1.388.1.10) [PATCH] fix layout of mapped files If you create a shared mapping of a sparse file, dirty it and then run msync, all the file's blocks are laid out backwards. This is because filemap_sync puts the lowest-index page at mapping->dirty_pages.prev and the highest at mapping->dirty_pages.next. I think that by walking the dirty pages list in ascending file offset order as we instantiate their disk mappings we will generally get better layout. <neilb@cse.unsw.edu.au> (02/03/11 1.388.1.11) [PATCH] PATCH - knfsd fixes for 2.5.6 Fix a few kNFSd problems. 1/ export svc_reserve which was introduced for NFS/TCP support. Without this we cannot load nfsd.o as a module 2/ the hash chain of clients was being changed (to put the found entry at the top of the list) while we only had a read-lock. This could corrupt the list and cause big problems. For now, just disable this code. Might add a lock later... 3/ lockd was calling exp_getclient without getting a readlock on the export table first. 4/ Add Config.help entry for CONFIG_NFSD_TCP <viro@math.psu.edu> (02/03/11 1.388.1.12) [PATCH] (1/4) ->kill_sb() switchover New method - ->kill_sb(). It will eventually replace current fs/super.c::shutdown_super() - i.e. it's called when fs driver must shut the superblock down, remove it from all lists, etc. <viro@math.psu.edu> (02/03/11 1.388.1.13) [PATCH] (2/4) ->kill_sb() switchover FS_LITTER filesystems (ramfs-like) switched to use of ->kill_sb(). FS_LITTER is gone. <viro@math.psu.edu> (02/03/11 1.388.1.14) [PATCH] (3/4) ->kill_sb() switchover The rest of nodev filesystems switched. <viro@math.psu.edu> (02/03/11 1.388.1.15) [PATCH] (4/4) ->kill_sb() switchover bdev filesystems switched. Changes documented in Locking and porting. <viro@math.psu.edu> (02/03/11 1.388.1.16) [PATCH] fix for get_sb_bdev() bug Grr... When loop in get_sb_bdev() had been switched from global list of superblock to per-type one, we should have switched from sb_entry(p) (aka. list_entry(p, struct super_block, s_list)) to list_entry(p, struct super_block, s_instances). As it is, we end up with false negatives all the time. I.e. second mount from the same block device with the same type gices a new superblock. With obvious nasty results... This fixes that. <rmk@flint.arm.linux.org.uk> (02/03/12 1.384.1.11) Add /dev/rtc support for Acorn machines. <rmk@flint.arm.linux.org.uk> (02/03/12 1.384.1.12) Update ARM tree for 2.5.6 <davem@nuts.ninka.net> (02/03/11 1.384.6.11) Update sparc64 defconfig. <davem@nuts.ninka.net> (02/03/11 1.384.6.12) Add sys_sendfile64 to sparc syscall tables. <dwmw2@infradead.org> (02/03/12 1.388.1.17) Update to 2002-03-12 JFFS2 development tree. Main features: - Preliminary version of NAND flash support. - Locking documentation and fixes (including BKL removal because it's superfluous). - Performance improvements - especially for mount time. - Annoying stuff like i_nlink on directories fixed. - Portability cleanups. <davem@nuts.ninka.net> (02/03/12 1.384.6.13) Fix sys32_sendfile64 implementation. <neilb@cse.unsw.edu.au> (02/03/12 1.393) [PATCH] PATCH - knfsd in 2.5.6 - fsid= export option Support fsid=<number> export option to be device number independent This patch was largely supplied by Steven Whitehouse <steve@gw.chygwyn.com> A new export option "NFSEXP_FSID" indicates that the ex_dev passed down is a user specified number, not a device number. It should be used in fsid_type==1 filehandles to identify the the exportpoint rather than the devid and inode (as in fsid_type == 0). This allows filehandles to be device-number independent so that when Linux changes device numbers on you (after reboot), your filesystems wont go stale. User-space support for this is in the nfs-utils CVS and will be in the next release (any release > 1.0). <sfr@canb.auug.org.au> (02/03/12 1.394) [PATCH] dnotify The following patch makes directory notifications per thread group instead of per process tree as they are now. This means, in particular, that if a child closes a file descriptor that has a directory open with notifies enabled, the notification will not be removed. Thanks to Andrea for the push in the right direction. <bgerst@didntduck.org> (02/03/12 1.395) [PATCH] struct superblock cleanup - minixfs Start of cleaning up the union of filesystem-specific structures in struct super_block. The goal is to remove dependence on filesystem headers in fs.h. This patch abstracts the access to the minix_sb_info structure through the function minix_sb(). <bgerst@didntduck.org> (02/03/12 1.396) [PATCH] struct superblock cleanup - minixfs Switch to using kmalloc to allocate the minix superblock structure. <sfr@canb.auug.org.au> (02/03/12 1.397) [PATCH] DMI patch for broken Dell laptop This adds DMI recognition for anohter broken Dell laptop BIOS (BIOS version A12 on the Insiron 2500). Reported by Mihnea-Costin Grigore <mgc8@totalnet.ro>. <john@deater.net> (02/03/12 1.398) [PATCH] pci=usepirqmask option. Last week I sent you a patch adding a config option to honor the pirq mask in the PCI routing table. On your suggestion, Cory Bell made it a command line option using the pci= interface and we both agree with you, it's -much- cleaner this way. Patch against 2.5.6 (Cory's submitting for 2.4, I've tested and submitting towards 2.5). All credit goes to Cory Bell, with only minor input and testing from myself. <viro@math.psu.edu> (02/03/12 1.399) [PATCH] (1/2) fs/super.c cleanups New helper - sget(). get_sb_bdev() and get_anon_super() switched to using it. Basically, it's get_anon_super() done right (and get_anon_super() itself will probably die). <viro@math.psu.edu> (02/03/12 1.400) [PATCH] (2/2) fs/super.c cleanups kill_super() and deactivate_super() merged. Next step will be to export these suckers - after that we will be finally done with infrastructure for filesystems with nontrivial ->get_sb(). <sfr@canb.auug.org.au> (02/03/12 1.401) [PATCH] Trivial APM update part 1 This is the first of a series of patches I have got from Thomas Hood that modify the apm code mainly for better self documentation. This one does: Variable "waiting_for_resume" is renamed 'ignore_sys_suspend'. The reason for the change is that this flag variable is employed in a manner analogous to that of other flag variables named 'ignore ...'. When the flag is set, the driver needs to ignore further system suspends. The driver does not "wait" in the usual sense of that word. The only sense in which the driver waits is the sense in which it needs to continue to ignore system suspends until certain events occur. One such event is a resume. However, another such event is the vetoing of the suspend request by a driver. So it would be more accurate to call the flag 'waiting_for_resume_or_suspend_reject' or something like that. But for the reason mentioned first, an even better name is 'ignore_sys_suspend'. <sfr@canb.auug.org.au> (02/03/12 1.402) [PATCH] Trivial apm update: eliminate 0 initializers Second in a series of patches from Thomas Hood. This patch eliminates the 0 initializers on three static variables inside the apm_cpu_idle function. These initializers are superfluous. The initializers are replaced with comments whose purpose is to indicate that the code relies upon the fact that these variables are initialized to zero at load time. <sfr@canb.auug.org.au> (02/03/12 1.403) [PATCH] Trivial apm patch: move apm_error up Here is the third one. This patch moves the apm_error() function higher in the file so that it is adjacent to the error_table that it uses. This makes the code easier to read. The beginning of the file is an appropriate place for "utility" functions of this kind. This is a pure move, with no changes made to the function. <sfr@canb.auug.org.au> (02/03/12 1.404) [PATCH] APM: move 'ignore_normal_resume = 1' This is number four and actually fixes a bug. This patch moves the setting of the ignore_normal_resume flag prior to the sti(); otherwise BIOS-generated normal resume events slip through unignored. <sfr@canb.auug.org.au> (02/03/12 1.405) [PATCH] Trivial APM patch: set_system_power_state Number 5 from Thomas Hood This patch renames the static function "apm_set_power_state" to 'set_system_power_state'. Generally, the prefix 'apm_' is required to prevent external name collisions on exported functions. This is a static function, so the prefix isn't required for that purpose. The prefix might also indicate that this function has something particularly to do with the apm subsystem; but that's not the case here. This function is simply a wrapper for set_power_state(), inserting the argument which sets the power state for the whole system. My main motivation for wanting to change this name is clearly to indicate the difference between this function and set_power_state(). Also, I would like to export set_power_state() someday in the future, but this is a separate issue. <sfr@canb.auug.org.au> (02/03/12 1.406) [PATCH] APM patch: change implementation of ALWAYS_CALL_BUSY Number 6 This patch cleans up the way the ALWAYS_CALL_BUSY macro forces calling of the APM BIOS busy routine. Instead of storing a false value in clock_slowed, we disjoin clock_slowed with the value of ALWAYS_CALL_BUSY. This simplifies the code. <sfr@canb.auug.org.au> (02/03/12 1.407) [PATCH] APM patch: apm_cpu_idle cleanups Number 7. This patch contains four cleanup changes whose aim is better code self-documentation (the best way to document IMHO). They are sent together because they overlap. 1. Rename the variable "sys_idle" to 'original_pm_idle'. This is where we store the value that we find in pm_idle before we substitute the address of our own apm_cpu_idle() function. In principle we have no idea whose address this is, so the variable name shouldn't imply that we know that this is the address of a system idle function; it should simply indicate that it is the original value of pm_idle. 2. Variable "apm_is_idle" is renamed 'apm_idle_done'. This flag indicates when apm_do_idle() has been called. It is a premise of apm_cpu_idle()'s operation that it is not known whether the apm_do_idle() function really idles the CPU. The name of the flag should not lead one to believe otherwise. 3. Variable "t1" is renamed 'bucket'. The variable is not a time but a countdown ("bucket"), so the variable name should not lead one to believe it is some sort of time value. 4. A default: case is added to the switch in order to remind the reader that there is a third possible return value from apm_do_idle(). <bgerst@didntduck.org> (02/03/12 1.408) [PATCH] struct super_block cleanup - cramfs Seperates cramfs_sb_info from struct super_block. <kraxel@bytesex.org> (02/03/12 1.410) [PATCH] video4linux doc fix This patch updates/fixes the video4linux API documantation. The current description for mmap() based capture is unclear and somewhat misleading. <kraxel@bytesex.org> (02/03/12 1.411) [PATCH] miropcm20 build fix This patch fixes the build failure of the miro radio driver due to the new location of the sound drivers in the tree (alsa merge). <kraxel@bytesex.org> (02/03/12 1.412) [PATCH] videodev redesign This patch is a redesign for videodev.[ch]. Changes: - drop the function pointers (read/write/mmap/poll/...) from struct video_device, use struct file_operations directly instead. Dispatching to different drivers by minor number is done the same way soundcore.o handles this: swap file->f_fops at open() time. - also drop the now obsolete video_red/write/mmap/poll/... functions from videodev.c - Stop using the BKL, use a mutex to protect open,register+unregister calls against races. - provide a video_generic_ioctl() function which can (and should) be used by v4l drivers to handle copying from and to userspace. - provide video_exclusive_open/release functions which can be used by v4l drivers to make sure only one process at a time opens the device. They can be hooked directly into struct file_operations if some driver has nothing to initialize at open time (which is true for many drivers in drivers/media/radio/). The move from function pointers in struct video_device to struct file_operations does break all existing v4l drivers. Thus I have a large number of patches for the drivers in the kernel tree. Most of it is just the adoption to the videodev.[ch] changes, but I've also fixed a small bug there and there while walking througth the source files. <kraxel@bytesex.org> (02/03/12 1.413) [PATCH] es1370 virt_to_bus fix This patch fixes the es1370 build problems due to virt_to_bus() being gone. <davem@nuts.ninka.net> (02/03/12 1.384.6.14) Include asm/page.h in sparc64 thread_info.h <torvalds@penguin.transmeta.com> (02/03/12 1.419) Update kernel version